九、ByteBuf浅层复制的高级使用方式
浅层复制是一种非常重要的操作。可以很大程度地避免内存复制。这一点对于大规模消息通信来说是非常重要的。
ByteBuf的浅层复制分为两种,有切片(slice)浅层复制和整体(duplicate)浅层复制。
slice切片浅层复制
ByteBuf的slice方法可以获取到一个ByteBuf的一个切片。一个ByteBuf可以进行多次的切片浅层复制;多次切片后的ByteBuf对象可以共享一个存储区域。
示例:
package com.crazymakercircle.netty.bytebuf;
//....
public class SliceTest {
@Test
public void testSlice() {
ByteBuf buffer = ByteBufAllocator.DEFAULT.buffer(9, 100);
print("动作:分配ByteBuf(9, 100)", buffer);
buffer.writeBytes(new byte[]{1, 2, 3, 4});
print("动作:写入4个字节 (1,2,3,4)", buffer);
ByteBuf slice = buffer.slice();
print("动作:切片slice", slice);
}
}
在上面代码中,输出了源ByteBuf和调用slice方法后的切片ByteBuf的三组属性值,运行结果如下:
//…篇幅原因,省略了B

文章介绍了Netty中的ByteBuf对象的两种浅层复制方法——slice切片复制和duplicate整体复制。slice方法创建的切片不可写,与源ByteBuf共享同一存储区域;duplicate则是整个ByteBuf的复制,包括读写指针和最大容量。由于浅层复制不复制底层数据且不改变引用计数,所以在源ByteBuf释放后,所有浅层复制实例也会失效,需谨慎处理引用计数。
最低0.47元/天 解锁文章
319

被折叠的 条评论
为什么被折叠?



