Use heap buffers for Unpooled.copiedBuffer()
Related issue: #2028 Motivation: Some copiedBuffer() methods in Unpooled allocated a direct buffer. An allocation of a direct buffer is an expensive operation, and thus should be avoided for unpooled buffers. Modifications: - Use heap buffers in all copiedBuffer() methods Result: Unpooled.copiedBuffers() are less expensive now.
This commit is contained in:
parent
0eac4fce29
commit
0dc6a8dccf
@ -375,10 +375,19 @@ public final class ByteBufUtil {
|
||||
* is allocated via the {@link ByteBufAllocator}.
|
||||
*/
|
||||
public static ByteBuf encodeString(ByteBufAllocator alloc, CharBuffer src, Charset charset) {
|
||||
return encodeString0(alloc, false, src, charset);
|
||||
}
|
||||
|
||||
static ByteBuf encodeString0(ByteBufAllocator alloc, boolean enforceHeap, CharBuffer src, Charset charset) {
|
||||
final CharsetEncoder encoder = CharsetUtil.getEncoder(charset);
|
||||
int length = (int) ((double) src.remaining() * encoder.maxBytesPerChar());
|
||||
boolean release = true;
|
||||
final ByteBuf dst = alloc.buffer(length);
|
||||
final ByteBuf dst;
|
||||
if (enforceHeap) {
|
||||
dst = alloc.heapBuffer(length);
|
||||
} else {
|
||||
dst = alloc.buffer(length);
|
||||
}
|
||||
try {
|
||||
final ByteBuffer dstBuf = dst.internalNioBuffer(0, length);
|
||||
final int pos = dstBuf.position();
|
||||
|
@ -412,12 +412,7 @@ public final class Unpooled {
|
||||
public static ByteBuf copiedBuffer(ByteBuf buffer) {
|
||||
int readable = buffer.readableBytes();
|
||||
if (readable > 0) {
|
||||
ByteBuf copy;
|
||||
if (buffer.isDirect()) {
|
||||
copy = directBuffer(readable);
|
||||
} else {
|
||||
copy = buffer(readable);
|
||||
}
|
||||
ByteBuf copy = buffer(readable);
|
||||
copy.writeBytes(buffer, buffer.readerIndex(), readable);
|
||||
return copy;
|
||||
} else {
|
||||
@ -637,6 +632,9 @@ public final class Unpooled {
|
||||
* {@code 0} and the length of the encoded string respectively.
|
||||
*/
|
||||
public static ByteBuf copiedBuffer(char[] array, Charset charset) {
|
||||
if (array == null) {
|
||||
throw new NullPointerException("array");
|
||||
}
|
||||
return copiedBuffer(array, 0, array.length, charset);
|
||||
}
|
||||
|
||||
@ -657,7 +655,7 @@ public final class Unpooled {
|
||||
}
|
||||
|
||||
private static ByteBuf copiedBuffer(CharBuffer buffer, Charset charset) {
|
||||
return ByteBufUtil.encodeString(ALLOC, buffer, charset);
|
||||
return ByteBufUtil.encodeString0(ALLOC, true, buffer, charset);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user