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&0xff
和i=b|0x00
不会得到相同的结果?
答案 0 :(得分:6)
首先,结果与字节完全无关。引用JLS section 15.22.1:
当运算符
&
,^,
或|
的两个操作数都是可转换的类型(第5.1.8节)为基本整数类型时,二进制数字促销是第一个在操作数上执行(第5.6.2节)。
因此,由于整数文字是int
(3.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
。