workQueue;// 互斥锁private final ReentrantLock mainLock = new ReentrantLock();// 包含线程池工作的所以线程 , 仅在持有mainLock的时候能访问private final HashSet workers = new HashSet();private final Condition termination = mainLock.newCondition();// 跟踪线程池最大的大小(实际的最大值) , 仅在持有mainLock的时候能访问private int largestPoolSize;// 记录已经完成的任务数 , 仅在工作线程终止时更新 , 仅在持有mainLock的时候能访问private long completedTaskCount;// 线程工厂private volatile ThreadFactory threadFactory;// 线程池饱和或者关闭时的执行器private volatile RejectedExecutionHandler handler;// 空闲线程等待工作的超时时间private volatile long keepAliveTime;// 如果为false(默认值) , 核心线程永远不回收// 如果为true , 核心线程也通过keepAliveTime参数超时回收private volatile boolean allowCoreThreadTimeOut;// 核心线程数private volatile int corePoolSize;// 最大线程数(程序设置的最大线程数 , 区别于largestPoolSize)private volatile int maximumPoolSize;// 默认的拒绝策略处理器 , 抛出RejectedExecutionException异常private static final RejectedExecutionHandler defaultHandler =new AbortPolicy();}涉及到的成员变量、常量比较多 , 也不太容易理解 , 不过看完整篇后再来回顾这里 , 就很容易理解了 。
生命周期ThreadPoolExecutor类提供了线程池的五个状态描述
// runState is stored in the high-order bitsprivate static final int RUNNING= -1 << COUNT_BITS;private static final int SHUTDOWN=0 << COUNT_BITS;private static final int STOP=1 << COUNT_BITS;private static final int TIDYING=2 << COUNT_BITS;private static final int TERMINATED =3 << COUNT_BITS;这几种状态之间的转换过程如下
![车驰夜幕|ThreadPoolExecutor线程池实现原理+源码解析]()
- RUNNING:运行状态 , 可以执行任务 , 也可以接受阻塞队列里的任务调度
- SHUTDOWN:调用了shutdown()方法 , 该状态可以继续执行阻塞队列中的任务 , 但是不会再接受新任务
- STOP:调用了shutdownNow()方法 , 该状态会尝试中断正在执行的所有任务 , 不能继续执行阻塞队列中的任务 , 也不会再接受新任务
- TIDYING:所有任务都执行完毕 , 至于阻塞队列中的任务是否执行完成 , 取决于调用了shutdown()还是shutdownNow()方法
- TERMINATED:terminated()方法执行完成后进入该状态 , terminated()方法默认没有任何操作
构造方法ThreadPoolExecutor提供了四个构造方法 , 忽略它提供的语法糖 , 我们直接看最吊的那个构造方法:
public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handler) {if (corePoolSize < 0 ||maximumPoolSize <= 0 ||maximumPoolSize < corePoolSize ||keepAliveTime < 0)// corePoolSize、maximumPoolSize、keepAliveTime都不能小于0// 且maximumPoolSize必须大于等于corePoolSizethrow new IllegalArgumentException();if (workQueue == null || threadFactory == null || handler == null)// workQueue、threadFactory、handler均不能为nullthrow new NullPointerException();this.corePoolSize = corePoolSize;this.maximumPoolSize = maximumPoolSize;this.workQueue = workQueue;this.keepAliveTime = unit.toNanos(keepAliveTime);this.threadFactory = threadFactory;this.handler = handler;}
推荐阅读
-
-
半年报|诚志股份收问询函 两子公司亏损商誉减值计提是否充分
-
-
微信|季后赛为何那么硬?巴特勒摊牌了:我要为队友们带来一个总冠军
-
-
水镜晓先生:已火速召回80万预备役,美军即将有大动作?命令海外公民迅速回国
-
-
好六网|DNF:“一笑”对水友太好,免费花3500帮打造,还为水友谋2万福利
-
人民日报|全球约一半新冠病例集中在3个国家 世卫称世界回不到过去状态
-
-
-
育儿房间儿女扬言断绝关系:如今,宝宝黏上了曾嫌弃自己的姐姐,67岁产女
-
-
「邵逸夫」刚刚,合肥交警集中回应电动车上牌问题!这种情况下罚款200元......
-
-
-
中国经济导报网 戴尔首家服务小企业的解决方案中心落户深圳
-
迪丽热巴|大反转!迪丽热巴黄景瑜双双沉默,狗仔放话怀孕消息来自私家侦探!
-
我国最“危险”的村子:四周都是悬崖峭壁,出门只能靠铁笼子
-
智米口罩了解一下:让你知道什么样的防霾口罩更“合心”?