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-07-29

14K+ 视图

开启你的 职业生涯

通过完成课程获得认证

开始
广告