今天看hashMap源码,看到做位运算的时候,用的是>>>移动位运算,于是乎查了下>>与>>>的用法
15 >> 2 = 315 >>> 2 = 3 |
就是将15除以4
二进制操作
0000 1111 >> 2 = 00000011 = 3,低位被丢失了0000 1111 >>> 2 = 00000011 = 3,低位也被丢失了由上面例子可知,正整数运算时,>>和>>>操作是没有区别的,
11110001 >> 2 = 11111100(还是一个负数,转换为十进制就是-4)11110001 >>> 2 = 00111100(这变成了正数了)由上可知 |
当对正数移位运算时,>>和>>>操作结果是一样的,
当对负数移位运算时,>>和>>>的操作结果是不一样的,>>将二进制高位用1补上,而>>>将二进制高位用0补上,这就导致了>>>将负数的移位操作结果变成了正数,因为高位用0补上了
本文探讨了Java中右移位运算符>>与无符号右移位运算符>>>的区别。在正整数运算时,两者效果相同,但处理负数时,>>会保留符号位,使用1填充高位,而>>>则用0填充高位,可能导致负数变为正数。

被折叠的 条评论
为什么被折叠?



