48、Netty源码分析:PooledByteBuf

PooledByteBuf

Netty中一大块内存块PoolChunk默认大小为4MB,为了尽可能充分利用内存会将它切成很多块PooledByteBufPooledByteBuf的类关系图如下:

*

PooledUnsafeDirectByteBufPooledUnsafeHeapByteBuf直接暴露对象的底层地址。

PooledByteBuf的创建过程开销很大,高并发情况下进行网络I/O时会创建大量的实例,为了降低系统开销,Netty将创建过的PooledByteBuf进行缓存重复利用。它的属性如下:

*

它的方法中比较重要的有:从channel中读数据getBytes()、从channel中写数据setBytes()、动态扩容capacity()、分配缓存allocate()、回收缓存deallocate()、回收利用recycle()

getBytes

*

分配得到的字节缓冲区与memory共享底层数据,但读/写索引单独维护。

checkIndex

*

ensureAccessible()

*

checkIndex0

*

_internalNioBuffer

newInternalNioBuffer()方法为抽象方法,此处与memory类型有关,可能是直接内存或者堆内存,因此其实现由具体的子类实现。

本文分析至此,更多后文再具体分析,感谢阅读。
*

版权声明:本文不是「本站」原创文章,版权归原作者所有 | 原文地址: