Java中的<< 和 >> 和 >>> 詳細分析
<<表示左移移,不分正負數,低位補0;
注:以下數據類型默認為byte-8位
左移時不管正負,低位補0
正數:r = 20 << 2
20的二進制補碼:0001 0100
向左移動兩位后:0101 0000
結果:r = 80
負數:r = -20 << 2
-20 的二進制原碼 :1001 0100
-20 的二進制反碼 :1110 1011
-20 的二進制補碼 :1110 1100
左移兩位后的補碼:1011 0000
反碼:1010 1111
原碼:1101 0000
結果:r = -80
>>表示右移,如果該數為正,則高位補0,若為負數,則高位補1;
注:以下數據類型默認為byte-8位
正數:r = 20 >> 2
20的二進制補碼:0001 0100
向右移動兩位后:0000 0101
結果:r = 5
負數:r = -20 >> 2
-20 的二進制原碼 :1001 0100
-20 的二進制反碼 :1110 1011
-20 的二進制補碼 :1110 1100
右移兩位后的補碼:1111 1011
反碼:1111 1010
原碼:1000 0101
結果:r = -5
>>>表示無符號右移,也叫邏輯右移,即若該數為正,則高位補0,而若該數為負數,則右移后高位同樣補0
正數: r = 20 >>> 2
的結果與 r = 20 >> 2 相同;
負數: r = -20 >>> 2
注:以下數據類型默認為int 32位
-20:源碼:10000000 00000000 00000000 00010100
反碼:11111111 11111111 11111111 11101011
補碼:11111111 11111111 11111111 11101100(在反碼基礎上加1)
右移:00111111 11111111 11111111 11111011
結果:r = 1073741819
總結(數學意義):
-
2 >> 1 = 1即左邊數除以2的1次方,右移n位就除以2的n次方(二進制右移肯定變小);
-
2 << 1 = 4即左邊數乘以2的1次方,左移n位就乘以2的n次方(二進制左移肯定變大);
-
2 >>> 1 = 1 正數無符號右移等於右移;
在移位運算時,byte、short和char類型移位后的結果會變成int類型,對於byte、short、char和int進行移位時,規定實際移動的次數是移動次數和32的余數,也就是移位33次和移位1次得到的結果相同。移動long型的數值時,規定實際移動的次數是移動次數和64的余數,也就是移動66次和移動2次得到的結果相同。
參考: