线程池是一个用来创建、管理线程的工具,线程池内部维护了若干个线程,没有任务的时候,这些线程都处于等待空闲状态。如果有新的线程任务,就分配一个空闲线程执行。如果所有线程都处于忙碌状态,线程池会创建一个新线程进行处理或者放入队列(工作队列)中等待。
- 提交一个新线程任务,线程池会在线程池中分配一个空闲线程,用于执行线程任务;
- 如果线程池中不存在空闲线程,则线程池会判断当前“存活的线程数”是否小于核心线程数 (corePoolsize)
- 如果小于核心线程数 corePoolsize,线程池会创建一个新线程(核心线程)去处理新线程任务;如果大于核心线程数 corePoolsize ,线程池会检查工作队列;
- 如果工作队列未满,则将该线程任务放入工作队列进行等待。线程池中如果出现空闲线程,将从工作队列中按照FIFO的规则取出1个线程任务并分配执行;如果工作队列已满,则判断线程数是否达到最大线程数 maximumPoolsize;
- 如果当前“存活线程数”没有达到最大线程数 maximumPoolsize ,则创建一个新线程(非核心线程)执行新线程任务,如果当前“存活线程数”已经达到最大线程数 maximumPoolsize ,直接采用拒绝策略处理新线程任务。
综上所述,执行顺序为:核心线程、工作队列、非核心线程、拒绝策略。
线程池的四种拒绝策略:
- AbortPolicy :默认策略,丢弃任务并抛出 RejectedExecutionException异常;
- DiscardPolicy :丢弃任务,不抛出异常;
- DiscardoldestPolicy :丢弃队列中的末尾任务(最老的任务,也就是最早进入队列的任务)后,重新将当前任务提交给线程池处理;
- CallerRunsPolicy :提交线程任务的业务线程直接执行线程任务的run()方法,线程池不再负责处理;