从位集屏蔽特定模式

Masking specific pattern from bitset

本文关键字:模式 屏蔽      更新时间:2023-10-16

设一个由 int 表示的位集。 编码到位集中的值是以下模式中的 0-15 范围的值0x0f0f0f0f。在我用上述模式屏蔽位集作为位掩码后,我如何"将这些单独的值推到一起"。 例如

1111 0001 1111 0001 1111 0001 1111 0001
-> 0000 0001 0000 0001 0000 0001 0000 0001 
-> 0000 0000 0000 0000 0001 0001 0001 0001

编辑

int bits = 0xf1f1f1f1;
int bit_mask = 0x0f0f0f0f;
// my_values == 0x01010101
int my values = bits & bit_mask;
// how can I turn my_values from 0x01010101 to 0x00001111 ? 

您需要提取您感兴趣的位并将它们向右移动。您可以同时屏蔽所需的位,因此无需先应用位掩码。像...

#include <iostream>
using namespace std;
void print_int_bits(uint32_t value)
{
for (uint32_t i=sizeof(uint32_t )*8-1;i>=0;--i)
std::cout << ((1 << i) & value ? "1" : "0");
std::cout << std::endl; 
}
int main() {
// int mask  = 0x0f0f0f0f; not needed
uint32_t value = 0b11110001111100011111000111110001;
//value &= mask; not needed, masked in the loop
uint32_t result = 0;
for(uint32_t i=0;i<4;++i)
result |= ((value & (0b00001111 << (i*8))) >> i*4);
print_int_bits(result);
return 0;
}

演示