今天看hashMap源码,看到做位运算的时候,用的是>>>移动位运算,于是乎查了下>>与>>>的用法
15 >> 2 = 3 15 >>> 2 = 3 |
就是将15除以4
二进制操作
0000
1111
>>
2
=
00000011
=
3
,低位被丢失了
0000
1111
>>>
2
=
00000011
=
3
,低位也被丢失了
由上面例子可知,正整数运算时,>>和>>>操作是没有区别的,
11110001 >> 2 = 11111100 (还是一个负数,转换为十进制就是- 4 ) 11110001 >>> 2 = 00111100 (这变成了正数了 ) 由上可知 |
当对正数移位运算时,>>和>>>操作结果是一样的,
当对负数移位运算时,>>和>>>的操作结果是不一样的,>>将二进制高位用1补上,而>>>将二进制高位用0补上,这就导致了>>>将负数的移位操作结果变成了正数,因为高位用0补上了