按位AND和OR运算的说明

时间:2015-12-07 11:12:13

标签: java bitwise-operators

public class ByteToIntTest {
    public static void main(String[] args) {
        byte b = -1;
        int i = b;
        System.out.println("i=b: "+i);
        i = b & 0xff;
        System.out.println("i=b&0xff: "+i);
        i = b | 0x00;
        System.out.println("i=b|0x00: "+i);
    }
}

结果是:

i=b: -1
i=b&0xff: 255
i=b|0x00: -1

为什么i=b&0xffi=b|0x00不会得到相同的结果?

1 个答案:

答案 0 :(得分:6)

首先,结果与字节完全无关。引用JLS section 15.22.1

  

当运算符&^,|的两个操作数都是可转换的类型(第5.1.8节)为基本整数类型时,二进制数字促销是第一个在操作数上执行(第5.6.2节)。

因此,由于整数文字是int3.10.1),操作数(因此每个byte)将转换为int

所以问题归结为以下几点:

public static void main(String[] args) {
    System.out.println(-1 & 0xff); // prints 255, why?
    System.out.println(-1 | 0x00); // prints -1, why?
}

&执行操作数值的按位AND。请考虑下表,其中每个int表示为其二进制字符串:

int        -> binary String
-1         -> 11111111111111111111111111111111
0xff (255) -> 00000000000000000000000011111111
0x00 (0)   -> 00000000000000000000000000000000

计算-1 & 0xff

  11111111111111111111111111111111
& 00000000000000000000000011111111
= 00000000000000000000000011111111

所以-1 & 0xff = 0xff = 255

对于第二种情况:

  11111111111111111111111111111111
| 00000000000000000000000000000000
= 11111111111111111111111111111111

所以-1 | 0x00 = -1