Java将int转换为字节时的奇怪行为?
int i =132;byte b =(byte)i; System.out.println(b);
令人难以置信。为什么输出-124?
回答:
在Java中,an int
是32位。A byte
是8 bits
。
最原始的类型Java中的签名,byte
,short
,int
,和long被编码在二进制补码。(char
类型为unsigned,并且sign的概念不适用于boolean
。)
在此数字方案中,最高有效位指定数字的符号。如果需要更多位,则将最高有效位(“ MSB”)简单复制到新的MSB中。
因此,如果你具有byte 255:11111111
并将其表示为int
32位,则只需将1复制到左侧24次。
现在,读取负数2的补码的一种方法是从最低有效位开始,向左移动直到找到第一个1,然后再将每一位取反。结果数字是该数字的正数
例如:11111111
转到00000001= -1
。这就是Java将显示为值的内容。
你可能想做的是知道字节的无符号值。
你可以使用位掩码完成此操作,该位掩码将删除除最低有效8位之外的所有内容。(0xff)
所以:
byte signedByte = -1;int unsignedByte = signedByte & (0xff);
System.out.println("Signed: " + signedByte + " Unsigned: " + unsignedByte);
将打印出: “Signed: -1 Unsigned: 255”
这里到底发生了什么?
我们使用按位AND来掩盖所有无关的符号位(最低有效8位左侧的1。)将int转换为字节时,Java砍掉最左侧的24位
1111111111111111111111111010101&
0000000000000000000000001111111
=
0000000000000000000000001010101
由于现在第32位是符号位,而不是第8位(并且我们将符号位设置为0,这是正数),因此Java读取字节中的原始8位作为正值。
以上是 Java将int转换为字节时的奇怪行为? 的全部内容, 来源链接: utcz.com/qa/408815.html