Java 二进制文字 - 字节值为 -128

标签 java binary byte literals twos-complement

从 SE 7 开始,Java 允许将值指定为二进制文字。文档告诉我“字节”是一种可以容纳 8 位信息的类型,值 -128 到 127。

现在我不知道为什么但我不能定义 8 位而只能定义 7 位如果我尝试将二进制文字分配给 Java 中的字节如下:

byte b = 0b000_0000;    //solves to the value 0
byte b1 = 0b000_0001;   //solves to the value 1
byte b3 = 0b000_0010;   //solves to the value 2
byte b4 = 0b000_0011;   //solves to the value 3     

依此类推,直到我们找到使用这 7 位的最后几种可能性:

byte b5 = 0b011_1111;   //solves to the value 63
byte b6 = 0b111_1111;   //solves to the value 127

如果我想让它成为负数,我必须像这样在前面添加一个前导 - :

byte b7 = -0b111_1111;   //solves to the value -127

现在我遇到的一半问题是我只使用 7 位来描述他们告诉我的是 8 位数据类型。下半部分是它们似乎不作为二进制补码进行线程化,除非使用 32 位 int 类型,我可以在其中定义所有 32 位(包括“符号指示位”)。

现在当我搜索如何显示范围内的数字 -128 时,我被告知要这样做而没有任何进一步的解释:

byte b8 = 0b1111_1111_1111_1111_1111_1111_1000_0000;

我可以清楚地看到最后的 8 位 (1000 0000) 确实代表 -128 在使用 8 位的二进制强制中,但我仍然没有更加困惑并尝试提出我的问题:

  • 上面的 32 位长不是 32 位 (java-) int 值吗?
  • 为什么我可以将 32 位值分配给 8 位 (java-) 字节类型?

或者一般来说:为什么我必须这样分配它?

关于此的任何链接/信息都很棒! 感谢您花时间阅读本文并提前了解更多信息。

问候 简

最佳答案

根据 Java 规范,

http://docs.oracle.com/javase/specs/jls/se7/html/jls-3.html#jls-3.10.1

所有 您的声明(b、b1、...和b8)都使用int 文字,即使它们适合一个字节。 Java 中没有字节字面量,只能使用 int 来初始化一个字节。

我做了一些测试,byte neg128 = -0b1000_0000; 工作正常。 0b1000_0000是128,所以你只需要在它前面放一个-符号。请注意,1 根本不是符号位(不要考虑 8 位字节,考虑转换为字节的 32 位整数)。因此,如果您想指定符号位,您需要写入所有 32 位,正如您所演示的那样。

所以 byte b8 = 0b1000_0000; 是一个错误,就像 byte b8 = 128; 是一个错误(+128 不适合一个字节)。您还可以使用强制转换强制转换:

byte b = (byte) 0b1000_0000; 要么 byte b = (byte) 128;

强制转换告诉编译器您知道 128 不适合一个字节并且位模式将被重新解释为 -128。

关于Java 二进制文字 - 字节值为 -128,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16775169/

相关文章:

java - int 的可变长度编码为 2 个字节

python - 在 Python 中将字节字符串转换为 float

python - 写入文件字节和字符串

java - 如何使用rapidminer创建标记输出集?

java - 大括号下的语句是否首先加载?

binary - Brainfuck 与 1 位存储单元?

algorithm - 二进制数的子集和

ruby - 在 CLI gem 中,我在哪里存储第三方二进制可执行文件?

java - 如何从 ViewPager 保存图像?

java - JAXP 与 XSD import ArrayIndexOutOfBoundsException