int i =132;
byte b =(byte)i; System.out.println(b);
令人难以置信。为什么输出是-124
?
最佳答案
在 Java 中,int
是 32 位。一个字节
是8位
。
Java 中的大多数基本类型都是带符号的,并且 byte
、short
、int
和 long
以二进制补码编码。 (char
类型是无符号的,符号的概念不适用于 boolean
。)
在此数字方案中,最高有效位指定数字的符号。如果需要更多位,则只需将最高有效位(“MSB”)复制到新的 MSB。
因此,如果您有字节255
:11111111
如果您想将其表示为 int
(32 位),只需将 1 复制到左侧 24 次即可。
现在,读取负的二进制补码数的一种方法是从最低有效位开始,向左移动直到找到第一个 1,然后反转每一位。结果数字是该数字的正数版本
例如:11111111
转到 00000001
= -1
。这就是 Java 将显示的值。
您可能想要做的是知道字节的无符号值。
您可以使用位掩码来完成此操作,该位掩码删除除最低有效 8 位之外的所有内容。 (0xff)
所以:
byte signedByte = -1;
int unsignedByte = signedByte & (0xff);
System.out.println("Signed: " + signedByte + " Unsigned: " + unsignedByte);
将打印出:“签名:-1 无签名:255”
这里到底发生了什么?
我们使用按位与来屏蔽所有无关的符号位(最低有效 8 位左侧的 1。) 当 int 转换为 byte 时,Java 会截掉最左边的 24 位
1111111111111111111111111010101
&
0000000000000000000000001111111
=
0000000000000000000000001010101
由于第 32 位现在是符号位而不是第 8 位(并且我们将符号位设置为 0,即正数),因此 Java 将字节中的原始 8 位读取为正值。
关于java - Java 将 int 转换为 byte 时的奇怪行为?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45080063/