Java 中的位運算右移運算元\n


Java 支援兩種型別的右移運算元。>> 運算元是有符號右移運算元,而 >>> 運算元是無符號右移運算元。左運算元的值向右移動右運算元指定的位數。

有符號右移運算元

有符號右移運算元 '>>' 使用符號位填充尾隨位置。例如,如果數字為正,則將 0 用於填充尾隨位置,如果數字為負,則將 1 用於填充尾隨位置。

假設 a = 60 和 b = -60;現在,以二進位制格式,它們將如下所示 −

a = 0000 0000 0000 0000 0000 0000 0011 1100
b = 1111 1111 1111 1111 1111 1111 1100 0100

在 Java 中,負數以 2 的補碼的形式儲存。

Thus a >> 1 = 0000 0000 0000 0000 0000 0000 0001 1110
And b >> 1 = 1111 1111 1111 1111 1111 1111 1110 0010

無符號右移運算元

無符號右移運算元 '>>>' 不使用符號位填充尾隨位置。它始終用 0 填充尾隨位置。

Thus a >>> 1 = 0000 0000 0000 0000 0000 0000 0001 1110
And b >>>  1 = 0111 1111 1111 1111 1111 1111 1110 0010

示例

線上演示

public class Tester {
   public static void main(String[] args) {
      int a = 60;          int b = -60;        int c = 0;
      System.out.println("60  = " + Integer.toBinaryString(a));
      System.out.println("-60 = " + Integer.toBinaryString(b));

      //signed shift
      c = a >> 1;              
      System.out.println("60 >> 1  = " + Integer.toBinaryString(c));

      //unsigned shift
      c = a >>> 1;            
      System.out.println("60 >>> 1 = " + Integer.toBinaryString(c) );

      c = b >> 1;              
      System.out.println("-60 >> 1  = " + Integer.toBinaryString(c) );

      c = b >>> 1;            
      System.out.println("-60 >>> 1 = " + Integer.toBinaryString(c));
   }
}

輸出

60  = 111100
-60 = 11111111111111111111111111000100
60 >> 1  = 11110
60 >>> 1 = 11110
-60 >> 1  = 11111111111111111111111111100010
-60 >>> 1 = 1111111111111111111111111100010

更新於: 2021 年 7 月 29 日

14K+ 瀏覽次數

開啟你的 職業生涯

完成課程獲得認證

開始
廣告
© . All rights reserved.