这是获取ByteBuffer中字节的推荐方式吗?
ByteBuffer bb =..
byte[] b = new byte[bb.remaining()]
bb.get(b, 0, b.length);
这是获取ByteBuffer中字节的推荐方式吗?
ByteBuffer bb =..
byte[] b = new byte[bb.remaining()]
bb.get(b, 0, b.length);
这取决于你想要做什么。
如果你想要检索剩余的字节(在位置和限制之间),那么你所拥有的就可以工作。你也可以这样做:
ByteBuffer bb =..
byte[] b = new byte[bb.remaining()];
bb.get(b);
根据ByteBuffer的文档,两者是等价的。
请注意,bb.array() 方法不考虑字节缓冲区的位置,如果你正在处理的字节缓冲区是其他缓冲区的片段,则可能会更糟。
也就是说,
byte[] test = "Hello World".getBytes("Latin1");
ByteBuffer b1 = ByteBuffer.wrap(test);
byte[] hello = new byte[6];
b1.get(hello); // "Hello "
ByteBuffer b2 = b1.slice(); // position = 0, string = "World"
byte[] tooLong = b2.array(); // Will NOT be "World", but will be "Hello World".
byte[] world = new byte[5];
b2.get(world); // world = "World"
这可能不是你想要做的事情。
如果你真的不想复制字节数组,一个解决方法是使用byte-buffer的arrayOffset() + remaining(),但前提是应用程序支持所需的字节缓冲区的索引+长度。
private static byte[] getByteArrayFromByteBuffer(ByteBuffer byteBuffer) {
byte[] bytesArray = new byte[byteBuffer.remaining()];
byteBuffer.get(bytesArray, 0, bytesArray.length);
return bytesArray;
}
java.nio.channels.Channels.WritableByteChannelImpl.write(ByteBuffer)
。有人知道这个答案是否有任何特殊的边界情况不能正常工作吗? - kevinarpefinal ByteBuffer buffer;
if (buffer.hasArray()) {
final byte[] array = buffer.array();
final int arrayOffset = buffer.arrayOffset();
return Arrays.copyOfRange(array, arrayOffset + buffer.position(),
arrayOffset + buffer.limit());
}
// do something else
如果一个人对给定的(直接)ByteBuffer的内部状态一无所知,并且想要检索缓冲区的全部内容,可以使用以下方法:
ByteBuffer byteBuffer = ...;
byte[] data = new byte[byteBuffer.capacity()];
((ByteBuffer) byteBuffer.duplicate().clear()).get(data);
ByteBuffer.get(byte[])
returns a ByteBuffer
- pybbyte[]
的简单方法,但使用ByteBuffer
的部分重点是避免创建byte[]
。也许您可以直接从ByteBuffer
中获取所需内容,而无需先获取byte[]
。
bb.capacity()
可能等于bb.remaining()
,因此您不能使用它们的相等性作为测试bb.array()
正确性的依据。请参见ByteBuffer.slice()
。 - cdunn2001bb.slice().remaining()
。这样看起来就像是一个干净的转储,而不会触及原始缓冲区。 - Kyllint
并使用位掩码:对于某个值k
,int unsigned_byte = b[k] & 0xff;
。 - Jason SByteBuffer#clear
吗? - Kenny Worden