《Netty》从零开始学netty源码(四十六)之PooledByteBuf
PooledByteBuf
Netty中一大块内存块PoolChunk默认大小为4MB,为了尽可能充分利用内存会将它切成很多块PooledByteBuf,PooledByteBuf的类关系图如下:
PooledUnsafeDirectByteBuf与PooledUnsafeHeapByteBuf直接暴露对象的底层地址。
PooledByteBuf的创建过程开销很大,高并发情况下进行网络I/O时会创建大量的实例,为了降低系统开销,Netty将创建过的PooledByteBuf进行缓存重复利用。它的属性如下:
它的方法中比较重要的有:从channel中读数据getBytes()
、从channel中写数据setBytes()
、动态扩容capacity()
、分配缓存allocate()
、回收缓存deallocate()
、回收利用recycle()
。
getBytes
分配得到的字节缓冲区与memory共享底层数据,但读/写索引单独维护。
checkIndex
ensureAccessible()
checkIndex0
_internalNioBuffer
newInternalNioBuffer()
方法为抽象方法,此处与memory类型有关,可能是直接内存或者堆内存,因此其实现由具体的子类实现。
本文分析至此,更多后文再具体分析,感谢阅读。