如何>>>运算符在Java中工作

时间:2012-07-17 16:32:58

标签: java binary bitwise-operators bit-shift

我理解>>>是如何运作的。要做到这一点,我有这个程序:

public class Main {
    public static void main(String[] args) 
    {
        short i = 130;
        byte b = (byte)i;
        String a = Integer.toBinaryString(256 + (int) b);
        System.out.println(Integer.toBinaryString(i));
        System.out.println(a.substring(a.length() -8));
        System.out.println(b);

        byte c = (byte) (b >>> 2);
        String x = Integer.toBinaryString(256 + (int) c);

        System.out.println(x.substring(x.length() -8));
        System.out.println(c);
    }
}

我得到了这个输出:

10000010
10000010
-126
11100000
-32

为了显示为二进制,我发现here如何将字节显示为二进制字符串。

运营商>>>会添加零,但我明白了:

-126
11100000
-63

而不是:

-126
10100000
-32

添加1而不是0:

11100000
10100000

我做错了什么?也许我什么都不懂。

1 个答案:

答案 0 :(得分:8)

问题是b >>> 2首先将b提升为值为-126的int,即

11111111 11111111 11111111 10000010

当你用零延伸向右移动2时,你得到:

00111111 11111111 11111111 11100000

当然后将其转换回一个字节时,它只会丢掉前三个单词,给出11100000,这就是你所看到的。

有关位移的详细信息,请参阅JLS的section 15.19