线程池的执行流程
如图所示,就是线程池的工作流程,可以分为五个步骤:
- 当有线程任务提交到线程池时,线程池会判断当前线程池中是否有空闲线程,如果存在空闲线程会优先分配空闲线程执行线程任务
- 当线程池中不存在空闲线程时,会判断当前线程池中的线程数是否小于核心线程数,如果小于核心线程数时会创建核心线程,并执行线程任务
- 如果当前线程数大于核心线程数时,线程池会判断当前线程池的工作队列是否已满,如果工作队列未满,会将线程任务加入到工作队列中,当线程池中存在空闲线程时,会按照先进先出的原则依次取出线程任务
- 当线程池的工作队列已满时,会判断当前线程池的最大线程数是否超出,未超出会创建非核心线程,并执行线程任务,当线程任务结束后,非核心线程会被回收
- 当当前线程池的线程数到达最大线程数时,会执行拒绝策略
常用的四种线程池及其特点
public class Test06 {
public static void main(String[] args) {
//创建ThreadPoolExecutor的线程池
//特点:线程池的数量是动态数量(线程会被缓存,空闲线程超过六十秒会被回收)
Executors.newCachedThreadPool();
//创建ThreadPoolExecutor的线程池
//特点:线程池的数量是固定的
Executors.newFixedThreadPool(10);
//创建ThreadPoolExecutor的线程池
//只有一个线程的线程池
Executors.newSingleThreadExecutor();
//创建ScheduledThreadPoolExecutor的线程池
// 这个线程池的工作队列是DelayedWorkQueue
Executors.newScheduledThreadPool(1);
}
}