Java中的<< 和 >> 和 >>> 詳細分析
<font color=#ff0000> <<表示左移移惩系,不分正負數(shù),低位補0如筛;</font>
注:以下數(shù)據(jù)類型默認為byte-8位
左移時不管正負堡牡,低位補0
正數(shù):<font color=#0000ff>r = 20 << 2</font>
20的二進制補碼:0001 0100
向左移動兩位后:0101 0000
結果: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
結果:r = -80
<font color=#ff0000> >>表示右移,如果該數(shù)為正杨刨,則高位補0晤柄,若為負數(shù),則高位補1拭嫁;</font>
注:以下數(shù)據(jù)類型默認為byte-8位
正數(shù):<font color=#0000ff>r = 20 >> 2</font>
20的二進制補碼:0001 0100
向右移動兩位后:0000 0101
結果:r = 5
負數(shù):r = -20 >> 2
-20 的二進制原碼 :1001 0100
-20 的二進制反碼 :1110 1011
-20 的二進制補碼 :1110 1100
右移兩位后的補碼:1111 1011
反碼:1111 1010
原碼:1000 0101
結果:r = -5
<font color=#ff0000>>>>表示無符號右移可免,也叫邏輯右移,即若該數(shù)為正做粤,則高位補0浇借,而若該數(shù)為負數(shù),則右移后高位同樣補0</font>
正數(shù): r = 20 >>> 2
的結果與 r = 20 >> 2 相同怕品;
負數(shù): r = -20 >>> 2
注:以下數(shù)據(jù)類型默認為int 32位
-20:源碼:10000000 00000000 00000000 00010100
反碼:11111111 11111111 11111111 11101011
補碼:11111111 11111111 11111111 11101100(在反碼基礎上加1)
右移:00111111 11111111 11111111 11111011
結果:r = 1073741819
總結(數(shù)學意義):
<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類型移位后的結果會變成int類型,對于byte炫乓、short刚夺、char和int進行移位時献丑,規(guī)定實際移動的次數(shù)是移動次數(shù)和32的余數(shù),也就是移位33次和移位1次得到的結果相同侠姑。移動long型的數(shù)值時创橄,規(guī)定實際移動的次數(shù)是移動次數(shù)和64的余數(shù),也就是移動66次和移動2次得到的結果相同莽红。
參考: