首先,结果与字节完全没有关系.引用JLS第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
.
首先,结果与字节完全没有关系.引用JLS第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
.