个人博客
ThreadPoolExecutor基于ctl变量的声明周期管理 | iwts’s blog
总集
想要完整了解下ThreadPoolExecutor?可以参考:
基于源码详解ThreadPoolExecutor实现原理 | iwts’s blog
ctl字段的应用
线程池内部使用一个变量ctl
维护两个值:
- 运行状态(runState)
- 线程数量 (workerCount)
在具体实现中,就是进行位运算:
COUNT_BITS
如果是32位的话,那么结合下面的一套左移、与、非的位运算,可以总结为:
- ctl的高3位保存runState,即运行状态。
- ctl的低29位保存workerCount,即有效线程数量。
除了ctl解析方法,还提供ctl计算方法,即根据runState和workerCount,计算出ctl值。
这样合并的好处是,操作的时候单锁就可以处理了(CAS也非常方便),位运算速度也快。