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

时间:2013-05-27 14:17:35

标签: java binary byte literals twos-complement

由于SE 7 Java允许将值指定为二进制文字。文档告诉我'byte'是一种可以保存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)在使用8位的两个强制中确实代表-128,但我从未对此感到困惑并尝试提出我的问题:

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

或者一般而言:为什么我必须这样分配?

任何关于此的链接/信息都会很棒! 感谢您花时间阅读本文以及提前获取的任何进一步信息。

此致 扬

1 个答案:

答案 0 :(得分:8)

根据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。