今天看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补上了