背景:对于线程池的执行流程,我们首先得知道什么是线程池,以及其核心配置参数。
什么是线程池?
线程池是用于创建管理和复用线程的一种技术,可以优化线程的执行效率。
线程池的核心配置参数:
观察源码图片可知,线程包含了七个核心配置参数
- corePoolSize: 核心线程数
- maximumPoolSize: 线程池最大线程数
- keepAliveTime: 非核心线程(临时线程)存活时间
- unit: 时间单位(非核心线程(临时线程)存活时间)
- workQueue: 阻塞工作队列
- defaultThreadFactory: 线程工厂
- defaultHandler: 拒绝策略
执行流程:
1.首先向线程池提交一个任务,线程池会分配一个空闲线程去执行这个任务。
2.如果线程池不存在空闲线程,那么线程池就会判断目前线程池中存活的数量。
如果线程池中存活线程的数量小于<核心线程数corePoolSize,线程池会创建一个核心线程,去处理提交的任务。
如果线程池中存活线程的数量大于>核心线程数corePoolSize,那么线程池会判断workQueue工作队列是否已满
如果workQueue工作队列未满,那么新提交的任务,会被放进任务队列workQueue排队等待执行。
3.当线程池中存活的线程数已经超出corePoolSize,并且任务队列workQueue已满,那么线程池会判断存活线程数是否达到maximumPoolSize,即最大线程数是否已满。
如果未达到maximumPoolSize最大线程数,线程池会创建一个非核心线程执行提交的任务。
如果当前存活线程数达到了maximumPoolSize最大线程数,直接执行拒绝策略处理。