《Java编程思想》学习笔记之操作符

如果对charbyte或者short类型的数值进行移位处理,那么在移位进行之前,它们会被转成int类型,并且得到的结果也是一个int类型的值。只有数值右端的低5位才有用。这样可防止我们移位超过int型值所具有的位数。(译注:因为2的5次方为32,而int型值只有32位。

这里的数值低5位指的是操作符右端移位数的低5位。因为int型值只有32位,所以移动32位或以上将彻底改变待移位数。故在Java中只取低5位,将移位数限制在0到31之间。则 a >> 33 等价于 a >> 1 。

“移位”可与“等号”(<<=或>>=或>>>=)组合使用。此时,操作符左边的值会移动由右边的值指定的位数,再将得到的结果赋给左边的变量。但在进行“无符号”右移位结合赋值操作时,可能会遇到一个问题:如果对byteshort值进行这样的移位运算,得到的可能不是正确的结果。它们会先被转换成int类型,再进行右移操作,然后被截断,赋值给原来的类型,在这种情况下可能得到-1的结果。

public class URShift {
    public static void main(String[] args) {
        byte b1 = -1;
        byte b2 = -1;
        System.out.println(Integer.toBinaryString(b1));
        System.out.println(Integer.toBinaryString(b2));
        b1 >>>= 10;
        b2 >>>= 25;
        System.out.println(Integer.toBinaryString(b1));
        System.out.println(Integer.toBinaryString(b2));
    }
} /* Output:
11111111111111111111111111111111
11111111111111111111111111111111
11111111111111111111111111111111
1111111

对于 b1 = -1 ,先被转换成int类型的 -1 ,其二进制表示为 11111111 11111111 11111111 11111111,再进行右移10位操作,得到 00000000 00111111 11111111 11111111,然后被截断为8位的byte类型 11111111,得到结果 b1 = -1 ,将其转化为int型二进制串的结果为 11111111 11111111 11111111 11111111 。

对于 b2 = -1 ,先被转换成int类型的 -1 ,其二进制表示为 11111111 11111111 11111111 11111111,再进行右移25位操作,得到 00000000 00000000 00000000 01111111,然后被截断为8位的byte类型 01111111,得到结果 b2 = 127 ,将其转化为int型二进制串的结果为 1111111 。

short类型的情况同理。


猜你喜欢

转载自blog.csdn.net/tyrannosar/article/details/80885500