Skip to content

Commit

Permalink
Use heap buffers for Unpooled.copiedBuffer()
Browse files Browse the repository at this point in the history
Related issue: netty#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.
  • Loading branch information
trustin committed Aug 13, 2014
1 parent 0eac4fc commit 0dc6a8d
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 8 deletions.
11 changes: 10 additions & 1 deletion buffer/src/main/java/io/netty/buffer/ByteBufUtil.java
Original file line number Diff line number Diff line change
Expand Up @@ -375,10 +375,19 @@ private static int lastIndexOf(ByteBuf buffer, int fromIndex, int toIndex, byte
* 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();
Expand Down
12 changes: 5 additions & 7 deletions buffer/src/main/java/io/netty/buffer/Unpooled.java
Original file line number Diff line number Diff line change
Expand Up @@ -412,12 +412,7 @@ public static ByteBuf copiedBuffer(ByteBuffer buffer) {
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 {
Expand Down Expand Up @@ -637,6 +632,9 @@ public static ByteBuf copiedBuffer(
* {@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);
}

Expand All @@ -657,7 +655,7 @@ public static ByteBuf copiedBuffer(char[] array, int offset, int length, Charset
}

private static ByteBuf copiedBuffer(CharBuffer buffer, Charset charset) {
return ByteBufUtil.encodeString(ALLOC, buffer, charset);
return ByteBufUtil.encodeString0(ALLOC, true, buffer, charset);
}

/**
Expand Down

0 comments on commit 0dc6a8d

Please sign in to comment.