位运算符对整数在内存中的二进制位进行操作,由于其具有运算速度快的特点,经常被用于性能优化。
&
位运算 AND
将两个数对应的二进制进行与
操作
|
位运算 OR
将两个数对应的二进制进行或
操作。
^
位运算 XOR
将两个数对应的二进制进行异或
操作。异或
是将二进制相同的位置为0
,不同的位置位1
。
&^
位清空 (AND NOT)
对于第二个数字来说,将第二个数字对应的位清空。其运算表如下
0 &^ 0 = 0 0 &^ 1 = 0 1 &^ 0 = 1 1 &^ 1 = 0
这个操作符通常用于清空对应的标志位,例如 a = 0011 1010
,如果想清空第二位,则可以这样操作
a &^ 0000 0010 = 0011 1000
<<
左移
将二进制向左移动,右边空出的位用0填补,高位左移溢出则舍弃该高位。由于每次移位数值会翻倍,所以通常用代替乘2操作。当然这是建立在移位没有溢出的情况。
>>
右移
将整数二进制向右移动,左边空出的位用0
或者1
填补。正数用0
填补,负数用1
填补。负数在内存中的二进制最高位为符号位——使用1
表示,所以为了保证移位之后符号位的正确性,所以需要在高位补1
。相对于左移来说,右移通常用来代替除2操作。
移位操作虽然方便高效,但是在使用过程中要注意溢出和舍弃的问题。
原文链接:https://www.f2er.com/go/187330.html