參考How do you set, clear and toggle a single bit in C?
c/c++中對(duì)二進(jìn)制位的操作包括設(shè)置某位為1、清除某位(置為0)、開關(guān)某位(toggling a bit)、檢查某位是否為1等。這些操作較為常見并且可以作為其他位運(yùn)算的基礎(chǔ)接口,以下羅列幾種方法:
傳統(tǒng)方法
number |= 1 << x; // 設(shè)置第x位為1
number &= ~(1 << x); // 置第x位為0
相應(yīng)地我們可以將其封裝起來,簡(jiǎn)便的方法是使用宏來封裝:
#define BIT_SET(a,b) ((a) |= (1<<(b)))
#define BIT_CLEAR(a,b) ((a) &= ~(1<<(b)))
#define BIT_FLIP(a,b) ((a) ^= (1<<(b)))
#define BIT_CHECK(a,b) ((a) & (1<<(b)))
使用位結(jié)構(gòu)操作
這個(gè)使用起來簡(jiǎn)單很多:
struct bits {
unsigned int a:1;
unsigned int b:1;
unsigned int c:1;
};
struct bits mybits;
// set/clear a bit
mybits.b = 1;
mybits.c = 0;
// toggle a bit
mybits.a = !mybits.a;
mybits.b = ~mybits.b;
mybits.c ^= 1;
// check a bit
if (mybits.c)
使用STL的std::bitset
這個(gè)方法其實(shí)類似于使用位結(jié)構(gòu),只不過STL包裝了這個(gè)結(jié)構(gòu)定義,當(dāng)然還提供了很多便捷的接口:
std::bitset<5> bits;
bits[0] = true;
bits[1] = false;
bits.set(2);
bits.flip(3);
bits.reset(2);