无符号位移(>>>)和有符号位移(>>)的区别是
有符号位移运算时如果数字为正数时位移后在前面补0,为负数时则在位移后在前面补1
举例说明最快
以15位例(负数以-15为例)
15的二进制 :00000000 00000000 00000000 00001111
-15的二进制:11111111 11111111 11111111 11110001
计算过程:补码(负数的二进制)=反码+1
反码:11111111 11111111 11111111 11110000
补码(即加1):11111111 11111111 11111111 11110001 也就是-15的二进制
一、正数 (无符号位移>>>)
15>>>2 注:2 移动的位数
15的二进制 :00000000 00000000 00000000 00001111
移动之后 :00000000 00000000 00000000 00000011 (11 舍弃)
计算之后:3
二、正数 (有符号位移>>)
15>>2
15的二进制 :00000000 00000000 00000000 00001111
移动之后:00000000 00000000 00000000 00000011 (11 舍弃) 同(>>>)
计算之后:3
三、负数(无符号位移>>>)
-15>>>2
-15的二进制:11111111 11111111 11111111 11110001
移动之后:00111111 11111111 11111111 11111100 (01舍弃)
这个数好大的,如何计算呢?
2^2+2^3+2^4+...+2^30=1073741820
计算结果:1073741820
四、负数(有符号位移>>)
-15>>2
-15的二进制:11111111 11111111 11111111 11110001
移动之后:11111111 11111111 11111111 11111100 (01舍弃)
补码(负数的二进制)=反码+1
先减1:11111111 11111111 11111111 11111011
反码:00000000 00000000 00000000 00000100 (此结果为4)
计算结果:-4
五、总结(不全面、不绝对)
15>>>2=3
15>>2=3
-15>>>2=1073741820
-15>>2=-4
当需要移位的数为正数时,有符号位移(>>)和无符号位移(>>>)是相同的。
当需要移位的数为负数时,有符号位移(>>)的结果 还为负数,无符号位移(>>>)的结果为正数。