我想要一个小端DWORD字节数组的无符号值。
这是我写的:
private long getUnsignedInt(byte[] data) {
long result = 0;
for (int i = 0; i < data.length; i++) {
result += (data[i] & 0xFF) << 8 * (data.length - 1 - i);
}
return result;
}
正确吗?
不行,恐怕是大端序。
public long readUInt(byte[] data) {
// If you want to tackle different lengths for little endian:
//data = Arrays.copyOf(data, 4);
return ByteBuffer.wrap(data)
.order(ByteOrder.LITTLE_ENDIAN)
.getInt() & 0xFF_FF_FF_FFL;
}
上面做了一个4字节到(有符号)int的转换,然后使其无符号
更正BigEndian
如果DWORD指的是32位无符号整型,试试这个
public long readUInt(byte[] data) {
return (
((long)(data[3] & 0xFF) << 24) |
((long)(data[2] & 0xFF) << 16) |
((long)(data[1] & 0xFF) << 8) |
((long)(data[0] & 0xFF) << 0));
}
jooop Eggen的答案是正确的,我认为这个更快,因为没有对象分配。