位运算

~(10011010) // (01100101)
(10010011) & (00111101) // (00010001)
(10010011) | (00111101) // (10111111)
(10010011) ^ (00111101) // (10101110)
(10001010) << 2 // (00101000)

对于有符号类型与无符号类型有不同的结果.
有符号类型的右移结果在不同系统中可能有差异.
无符号类型的右移结果在所有系统中都相同.

(10001010) >> 2 // (00100010) 无符号右移
// 乘法
number << n // number乘以2的n次幂
// 除法
number >> n // 如果number为非负值, number除以2的n次幂

掩码是一种利用位运算操作二进制数的方法.

flags = 00001111
MASK = 10110110 // 打开所有为1的位
flags = flags | MASK // 10111111
flags = 00001111
MASK = 10110110 // 关闭所有为1的位
flags = flags & ~MASK // 00001001
flags = 00001111
MASK = 10110110 // 取反所有为1的位
flags = flags ^ MASK // 10111001
flags = 00001111
MASK = 00001001 // 检查第1位和第4位是否为1
if ((flags & MASK) === MASK) { // 当位的值如掩码预期时为真
...
}

C语言可以使用struct和unsigned int表示一种按二进制位存储的结构, 这在文件操作和网络通信中很有用.

struct box_props {
bool opaque: 1; // 开关位
unsigned int fill_color: 3; // 只占3位的值
unsigned int: 4; // 填充位
bool show_border: 1; // 开关位
unsigned int border_color: 3; // 只占3位的值
unsigned int border_style: 2; // 只占2位的值
unsigned int: 2; // 填充位
} // 一个长度为16位的结构