56、Netty源码分析:PoolThreadLocalCache

本文深入解析Netty中PoolThreadLocalCache的源码实现,详细讲解其如何管理PoolThreadCache以提供线程本地内存缓存,包括get()、set()、remove()方法的工作原理以及与Java ThreadLocal的性能对比,帮助开发者理解Netty高性能内存池的核心机制。

PoolThreadLocalCache

前面讲到PoolThreadCache,它为线程提供内存缓存,当线程需要分配内存时可快速从其中获取,在Netty中用PoolThreadLocalCache来管理PoolThreadCache,它的数据结构如下:
 

PoolThreadLocalCache相当于java的ThreadLocal,我们知道ThreadLocal中维护的是ThreadLocalMap,使用hashcode来做下标,而Netty中自己维护了一个InternalThreadLocalMap,内部使用的是一个数组来存放变量值,使用index来寻找当前线程对应的变量,它的性能比map要好一些。

接下来分析它的三个方法:get()set()remove()

get()

 

子类PoolThreadLocalCache对initialize()方法进行重写:
 

接下来我们看下定时任务trimTask()

trimTask

 

set()

 

如果变量值value有效则将其放入map中,否则将其删除,接下来具体分析这两个方法。

setKnownNotUnset()

 

remove()

删除的时候需要两步,第一步是先将其从待删除列表中删除,第二步则是对象自己本身的清除工作。

 

removeFromVariablesToRemove()

 

onRemoval()

 

至此,PoolThreadLocalCache分析至此完毕。
 

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