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