[英]How to get a signed 32 bit integer from hex bytes without being 2's complement applied to it in java
[英]Java: 4 bytes to 32 bit integer
我试图理解以下代码:
int omgezetteTijd =
((0xFF & rekenOmNaarTijdArray[0]) << 24) | ((0xFF & rekenOmNaarTijdArray[1]) << 16) |((0xFF & rekenOmNaarTijdArray[2]) << 8) | (0xFF & rekenOmNaarTijdArray[3]);
我不明白的是为什么你用 OxFF 与它进行 AND 运算,你将一个 8 位值与 8 位像这样 (11111111),所以这应该给你相同的结果。
但是,当我不将它与 OxFF 进行 AND 运算时,我会得到负值吗? 无法弄清楚为什么会这样?
当您或一个带有 int 的字节时,该字节将被提升为一个 int。 默认情况下,这是通过符号扩展完成的。 换句话说:
// sign bit
// v
byte b = -1; // 11111111 = -1
int i = (int) b; // 11111111111111111111111111111111 = -1
// \______________________/
// sign extension
通过执行& 0xFF
可以防止这种情况。 IE
// sign bit
// v
byte b = -1; // 11111111 = -1
int i = (int) (0xFF & b); // 00000000000000000000000011111111 = 255
// \______________________/
// no sign extension
0xFF 作为一个byte
代表数字-1。 当它转换为int
,它仍然是 -1,但由于符号扩展,它的位表示为0xFFFFFFFF
。 & 0xFF
避免了这种情况,在转换为 int 时将字节视为无符号。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.