ByteBuf.readBytes(...) should use the allocator of the buffer to create the new buffer. Related to [#5093]
Motivation: ByteBuf.readBytes(...) uses Unpooled.buffer(...) internally which will use a heap ByteBuf and also not able to make use of the allocator which may be pooled. We should better make use of the allocator. Modifications: Use the allocator for thenew buffer. Result: Take allocator into account when copy bytes.
This commit is contained in:
parent
856d6b9402
commit
8d63aae484
@ -674,8 +674,7 @@ public abstract class AbstractByteBuf extends ByteBuf {
|
|||||||
return Unpooled.EMPTY_BUFFER;
|
return Unpooled.EMPTY_BUFFER;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use an unpooled heap buffer because there's no way to mandate a user to free the returned buffer.
|
ByteBuf buf = alloc().buffer(length, maxCapacity);
|
||||||
ByteBuf buf = Unpooled.buffer(length, maxCapacity);
|
|
||||||
buf.writeBytes(this, readerIndex, length);
|
buf.writeBytes(this, readerIndex, length);
|
||||||
readerIndex += length;
|
readerIndex += length;
|
||||||
return buf;
|
return buf;
|
||||||
|
@ -1227,6 +1227,7 @@ public abstract class AbstractByteBufTest {
|
|||||||
// Make sure if it is a copied buffer.
|
// Make sure if it is a copied buffer.
|
||||||
actualValue.setByte(0, (byte) (actualValue.getByte(0) + 1));
|
actualValue.setByte(0, (byte) (actualValue.getByte(0) + 1));
|
||||||
assertFalse(buffer.getByte(i) == actualValue.getByte(0));
|
assertFalse(buffer.getByte(i) == actualValue.getByte(0));
|
||||||
|
actualValue.release();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2523,6 +2524,21 @@ public abstract class AbstractByteBufTest {
|
|||||||
assertEquals(0, readOnlyDst.position());
|
assertEquals(0, readOnlyDst.position());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadBytes() {
|
||||||
|
ByteBuf buffer = newBuffer(8);
|
||||||
|
byte[] bytes = new byte[8];
|
||||||
|
buffer.writeBytes(bytes);
|
||||||
|
|
||||||
|
ByteBuf buffer2 = buffer.readBytes(4);
|
||||||
|
assertSame(buffer.alloc(), buffer2.alloc());
|
||||||
|
assertEquals(4, buffer.readerIndex());
|
||||||
|
assertTrue(buffer.release());
|
||||||
|
assertEquals(0, buffer.refCnt());
|
||||||
|
assertTrue(buffer2.release());
|
||||||
|
assertEquals(0, buffer2.refCnt());
|
||||||
|
}
|
||||||
|
|
||||||
private void testRefCnt0(final boolean parameter) throws Exception {
|
private void testRefCnt0(final boolean parameter) throws Exception {
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
final CountDownLatch latch = new CountDownLatch(1);
|
final CountDownLatch latch = new CountDownLatch(1);
|
||||||
|
@ -117,7 +117,13 @@ public class SlicedByteBufTest extends AbstractByteBufTest {
|
|||||||
@Test
|
@Test
|
||||||
@Override
|
@Override
|
||||||
public void testLittleEndianWithExpand() {
|
public void testLittleEndianWithExpand() {
|
||||||
// ignore for SlicedByteBuf
|
// ignore for SlicedByteBuf
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Override
|
||||||
|
public void testReadBytes() {
|
||||||
|
// ignore for SlicedByteBuf
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Loading…
x
Reference in New Issue
Block a user