位运算:
& 按位与 #都是1结果为1,只有一个1结果为0
| 按位或 #有1结果就为1
^ 按位异或 #不同为1,相同为0,如00011101^10011010 结果10000111
~ 按位取反 #
<<按位左移 #左移一位--------相当于乘2
>>按位右移 #右移一位--------相当于除2
作用:直接操作二进制,省内存,效率高
取反是对补码进行操作:如 ~9=-10
步骤:9的原码=反码=补码
0000 1001
1.对补码取反得下
1111 0110
2.再将补码转化为原码
规则:符号位不变,其他位取反,再加1
1000 1001 #变成了负数
再+1得
1000 1010 ==== -10
所以~9=-10
PS:补码求原码
(1)如果补码的符号位为“0”,表示是一个正数,所以补码就是该数的原码。
(2)如果补码的符号位为“1”,表示是一个负数,求原码的操作可以是:符号位为1,其余各位取反,然后再整个数加1。