<<(左移) 符號位不變,通過從右推入零向左位移,并使最左邊的位脫落
>>(右移) 符號位不變,通過從左推入最左位的拷貝來向右位移,并使最右邊的位脫落
>>>(無符號右移) 通過從左推入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