线程池的执行流程
- 提交一个新的线程任务,线程池会在线程池中分配一个空闲线程(ps:不会一次性创建指定的核心线程数,而是来一个任务创建一个新的空闲的核心线程,到核心线程数饱和为止),用于执行任务。
- 如果线程池中不存在空闲线程,线程池会判断当前“存活的线程数”是否小于核心线程数。
- 如果 小于 核心线程数
corePoolSize
,线程池会创建一个新的核心线程去处理新的线程任务; - 如果 大于 核心线程数
corePoolSize
,线程池会检查工作队列是否已满;- 如果工作队列未满,则将该线程任务加入工作队列进行等待。线程池中如果出现空闲的线程,将从工作队列中按照先进先出规则取出一个线程任务进行分配执行;
- 如果工作队列已满,则判断当前存活的线程数是否达到最大线程数
maximumPoolSize
;- 如果当前“存活的线程数”没有达到最大线程数
maximumPoolSize
,那么将创建一个临时的非核心线程执行新线程任务; - 如果当前“存活的线程数”已经达到最大线程数
maximumPoolSize
,那么将执行拒绝策略处理新线程任务;
综上所述,执行顺序为:核心线程、工作队列、非核心线程、拒绝策略
- 如果当前“存活的线程数”没有达到最大线程数
- 如果 小于 核心线程数
线程池执行流程图: