java - Java 将 int 转换为 byte 时的奇怪行为?

标签 java

int i =132;

byte b =(byte)i; System.out.println(b);

令人难以置信。为什么输出是-124

最佳答案

在 Java 中,int 是 32 位。一个字节是8

Java 中的大多数基本类型都是带符号的,并且 byteshortintlong 以二进制补码编码。 (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/

相关文章:

java - 是什么导致 JBoss 7.1.1 中出现此 SQL/Hibernate 错误?

java - Mockito 和 Spring Autowiring

java - 如何在swing应用程序中创建自动隐藏滚动条?

java - If 语句错误

java - Java Integer 和 Double 对象是否有不必要的开销?

Java 等待组件被绘制

java - 在方法 CompareTo(E) 中找不到符号

java - 使用Spring 3.0的 session 不活动弹出警告

java - 如何在JAVA中使用JMF控制mp3音频音量

java - 从 base64.decode 创建 imageview