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类型有关,可能是直接内存或者堆内存,因此其实现由具体的子类实现。文章来源:https://www.toymoban.com/news/detail-429138.html
本文分析至此,更多后文再具体分析,感谢阅读。
文章来源地址https://www.toymoban.com/news/detail-429138.html
到了这里,关于《Netty》从零开始学netty源码(四十六)之PooledByteBuf的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!