<<(左移) 符号位不变,通过从右推入零向左位移,并使最左边的位脱落
>>(右移) 符号位不变,通过从左推入最左位的拷贝来向右位移,并使最右边的位脱落
>>>(无符号右移) 通过从左推入0来向右位移,并使最右边的位脱落
计算过程
原码 ---> 反码 ---> 补码 ---> 计算 ---> 反码 ---> 原码(计算结果)
下面使用 10 和 -10 的 8位二进制 举例说明:
左移(<<)
10 << 2 = 40
000 1010 ---> 0000 1010 ---> 0000 1010 ---> 0010 1000 ---> 0010 1000 ---> 0010 1000 ---> 40
-10 << 2 = -40
1000 1010 ---> 1111 0101 ---> 1111 0110 ---> 1101 1000 ---> 1101 0111 ---> 1010 1000 ---> -40
右移(>>)
10>> 2 = 2
0000 1010 ---> 0000 1010 ---> 0000 1010 ---> 0000 0010 ---> 0000 0010 ---> 0000 0010 ---> 2
-10 >> 2 = -3
1000 1010 ---> 1111 0101 ---> 1111 0110 ---> 1111 1101 ---> 1111 1100 ---> 1000 0011 ---> -3
无符号右移(>>>)
10 >>> 2 = 2
0000 1010 ---> 0000 1010 ---> 0000 1010 ---> 0000 0010 ---> 0000 0010 ---> 0000 0010 ---> 2
-10 >>> 2 = 67 (结果会根据数据类型发生改变 byte、short、int、long)
1000 1010 ---> 1111 0101 ---> 1111 0110 ---> 0011 1101 ---> 0011 1100 ---> 0100 0011 ---> 67