分析:X &= ~(1<<3); /* bit3清零 */
~(1<<3)是1左移三位后取反,即0000 1000取反后为,1111 0111;相当于1111 0111 & 谁,第三位肯定会被清零,且其它位不受影响。
再分析:X |= (1<<3); /* bit3置1 */
(1<<3)是1左移三位,即0000 1000 按位或( | )上谁,第三位肯定会被置1,且其它位不受影响。
下表摘自C运算符 菜鸟教程。下表显示了 C 语言支持的位运算符。假设变量 A 的值为 60(0011 1100),变量 B 的值为 13,则:
运算符 | 描述 | 实例 |
---|---|---|
& | 按位与操作,按二进制位进行"与"运算。运算规则: 0&0=0; 0&1=0; 1&0=0; 1&1=1; | (A & B) 将得到 12,即为 0000 1100 |
| | 按位或运算符,按二进制位进行"或"运算。运算规则: 0|0=0; 0|1=1; 1|0=1; 1|1=1; | (A | B) 将得到 61,即为 0011 1101 |
^ | 异或运算符,按二进制位进行"异或"运算。运算规则: 0^0=0; 0^1=1; 1^0=1; 1^1=0; | (A ^ B) 将得到 49,即为 0011 0001 |
~ | 取反运算符,按二进制位进行"取反"运算。运算规则: ~1=-2; ~0=-1; | (~A ) 将得到 -61,即为 1100 0011,一个有符号二进制数的补码形式。 |
<< | 二进制左移运算符。将一个运算对象的各二进制位全部左移若干位(左边的二进制位丢弃,右边补0)。 | A << 2 将得到 240,即为 1111 0000 |
>> | 二进制右移运算符。将一个数的各二进制位全部右移若干位,正数左补0,负数左补1,右边丢弃。 |