所以我这里有一个小问题,我不知道可能出了什么问题。 这就是为什么我要问这个(我现在向你展示的)是否正确。 我正在将二进制文件转换为字节列表,以便我可以将这些字节转换为半字节。 例如: 如果我得到十进制数 96(十六进制数 60),我想从中得到 6 和 0。 127(十六进制:7F)也是如此 - 我想要得到 7 和 15。为了实现这一点,我编写了以下代码: 您会注意到,我需要“无符号字节”才能工作
System.out.println((byte) ((UnsignedByte.unsignedToBytes(b) - (UnsignedByte.unsignedToBytes(b) % 16)) / 16));
System.out.println((byte) (UnsignedByte.unsignedToBytes(b) % 16));
public static int unsignedToBytes(byte b) {
return b & 0xFF;
}
我做错了什么还是这不是问题?
最佳答案
使用位移位和按位运算:
- 要获取低四位,请使用
lowerNibble = WholeByte & 0x0F
- 要获取高四位,请使用
upperNibble = (wholeByte >> 4) & 0x0F
这会忽略符号,因为数字的上部被 & 0x0F
截断。
关于java - 将有符号字节转换为无符号半字节,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36253694/