(右移) 和 >>>(無符號右移)

移位運算符就是在二進制的基礎上對數字進行平移。

按照平移的方向和填充數字的規則分爲三種:

<<(左移)、>>(帶符號右移)和>>>(無符號右移)。
  在移位運算時,byte、short和char類型移位後的結果會變成int類型,對於byte、short、char和int進行移位時,規定實際移動的次數是移動次數和32的餘數,也就是移位33次和移位1次得到的結果相同。移動long型的數值時,規定實際移動的次數是移動次數和64的餘數,也就是移動66次和移動2次得到的結果相同。


  三種移位運算符的移動規則和使用如下所示:
  <<運算規則:

按二進制形式把所有的數字向左移動對應的位數,高位移出(捨棄),低位的空位補零。
  語法格式:
  需要移位的數字 << 移位的次數
  例如: 3 << 2,則是將數字3左移2位
  計算過程:
  3<< 2
  首先把3轉換爲二進制數字

0000 0000 0000 0000 0000 0000 0000 0011,

然後把該數字高位(左側)的兩個零移出,其他的數字都朝左平移2位,最後在低位(右側)的兩個空位補零。則得到的最終結果是

0000 0000 0000 0000 0000 0000 0000 1100,

則轉換爲十進制是12.


  >>運算規則:

按二進制形式把所有的數字向右移動對應位數,低位移出(捨棄),

高位的空位補符號位,即正數補零,負數補1.
  語法格式:
  需要移位的數字 >> 移位的次數
  例如11 >> 2,則是將數字11右移2位
  計算過程:

11的二進制形式爲:

0000 0000 0000 0000 0000 0000 0000 1011,

然後把低位的最後兩個數字移出,因爲該數字是正數,所以在高位補零。則得到的最終

結果是:

0000 0000 0000 0000 0000 0000 0000 0010.

轉換爲十進制是2.


  >>>運算規則:

按二進制形式把所有的數字向右移動對應位數,低位移出(捨棄),高位的空位補零。

無論正數還是負數都在高位插入0;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章