我有一个字节数组,需要重新打包到long数组.输入字节数组的大小未知(大致从0到几百). long数组需要右对齐,即最低索引long应填充零,其他所有其他数据应填充输入字节:
. (b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,b11) – > (xxxxb0b1b2b3,b4b5b6b7b8b9b10b11)
其中b1,b2等是给定的字节.
我有一个解决方案,但它不是很整洁或可读:
// outArr has length (inArr.length+7)/8
for (int i = 0; i < inArr.length ; i++) {
outArr[outArr.length - i/8 - 1] |= ((long)inArr[inArr.length - i - 1]) << (i % 8) * 8;
}
这样做有一种不那么丑陋的方式吗?
最佳答案 可能有更优雅的方法,但一种方法是使用java.nio缓冲区来转换它.由于需要将输入数组与8个字节块对齐,因此需要更多步骤:
int padding = outArr.length * 8 - inArr.length;
ByteBuffer buffer = ByteBuffer.allocate(inArr.length + padding)
.put(new byte[padding]).put(inArr);
buffer.flip();
buffer.asLongBuffer().get(outArr);