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分析至此完毕。