为什么Java中的整数为-1零填充右移1 = 2147483647?

对于以下程序:
public class ZeroFillRightShift
{
  public static void main(String args[])
  {
    int x = -1;
    int y = x>>>1;
    System.out.println("x = " + x);
    System.out.println("y = " + y);
  }
}

我得到的输出如下:

x = -1
y = 2147483647

我得到-1>>> 1的结果是2147483647.如果这是符号位必须被移位,据我所知,结果应该是1073741824.为什么是2147483647呢?

以下图像更清楚地说明了我的问题:

解决方法

The unsigned right shift operator “>>>” shifts a zero into the
leftmost position,while the leftmost position after “>>” depends on
sign extension.

所以,-1以零扩展向右移位一位,这意味着它会将0插入最左边的位置.记住,我们在这里处理two’s complement

-1为:11111111111111111111111111111111或十六进制0xFFFFFFFF

-1>>> 1是十六进制中的01111111111111111111111111111111或0x7FFFFFFF,它是231 – 1 == 2147483647

以下是shift operators的JLS参考.

你似乎对两个人的补充感到困惑.该值用于31位,并且最左边的位用于符号.由于你只是移位1位,有符号位变为0,这意味着正数,结果是最大的正数,而不是int可以表示.

也许另一个例子会有所帮助.我们来考虑一下:

System.out.println(-2 >> 1); //prints -1

-2 = 1111111111111111111111111111111110

如果我们使用已签名的右移,我们得到:11111111111111111111111111111111,这是-1.但是,如果我们这样做:

System.out.println(-2 >>> 1); //prints 2147483647

由于-2 = 11111111111111111111111111111110并进行无符号右移,这意味着我们以零扩展方式移位1位,给出:011111111111111111111111111111

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...