在我们开发中有时为了速率往往要用到位移运算符,今天将自己了解的做一个总结:
0000 0000 0000 0000表示正数的0
1111 1111 1111 1111表示-1,其中第一位为符号位,在计算机中会显示,一般计算中忽略第一位。
看看它为什么是-1:如果是有符号数,题中给的是补码,最左边的1表示负,仅考虑剩下的
111 1111 1111 1111 ,减去1后,得反码,即
1111 1111 1111 1110 ,按位取反,得原码,即
1000 0000 0000 0001 ,最左边的1仅表示负号,
所以转为十进制数,加上符号,得 - 1 .
<< : 左移运算符,num << 1,相当于num转换成二进制后向左移动1位,低位补0,num为负数时一样。
自己的理解:num << 1,相当于num乘以2,向下延伸当num<<2,相当于num乘以4,即乘以2的指数型倍数
一般来说二进制
>> : 右移运算符,num >>1,相当于num转换成二进制后向右移动1位,高位位补0,num为负数时,高位补1.
自己的理解: num >> 1,相当于num除以2,当num为奇数时,相当于Math.Floor,向下取整,当然当
num>>2时,相当于除以4,也是以2的指数型倍数递增。
>>> : 无符号右移,忽略符号位,空位都以0补齐