我试图转换一个无符号的有符号字节。问题是我接收的数据是无符号的,Java不支持无符号字节,所以当它读取数据时,它将其视为有符号的。
我尝试通过下面的解决方案转换它,我从Stack Overflow。
public static int unsignedToBytes(byte a)
{
int b = a & 0xFF;
return b;
}
但是当它再次以字节为单位转换时,我得到了相同的带符号数据。我试图使用此数据作为参数的Java函数,只接受一个字节作为参数,所以我不能使用任何其他数据类型。我该如何解决这个问题?
你还可以:
public static int unsignedToBytes(byte a)
{
return (int) ( ( a << 24) >>> 24);
}
解释:
假设a = (byte) 133;
在内存中,它被存储为:"1000 0101"(十六进制中的0x85)
所以它的表示可以转换为unsigned=133, signed=-123(作为2的补码)
A << 24
当向左移动24位时,结果现在是一个4字节的整数,表示为:
"10000101 00000000 00000000 00000000"(或十六进制中的"0x85000000")
然后我们有
(a << 24) >>>
它又向右移动了24位,但前导都是0。结果是:
"00000000 00000000 00000000 10000101"(或十六进制中的"0x00000085")
这就是无符号表达式它等于133。
如果你试图强制转换a = (int) a;
然后会发生的是,它保留了字节的2补表示,并将其存储为int,同时也存储为2的补:
(int)“10000101”——>“11111111 11111111 11111111 10000101”
翻译过来就是-123