56、Netty源码分析:PoolThreadLocalCache

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

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