线程池

1.三种创建线程池的方式:

Executors.newFixedThreadPool(5);
Executors.newSingleThreadExecutor();
Executors.newCachedThreadPool();

三者底层均是使用ThreadPoolExecutor实现的

2.ThreadPoolExecutor参数介绍

上面使用的构造函数中仅传入了5个参数,实际上构造器共有7个参数:

corePoolSize: 线程池中的常驻核心线程数
maximumPoolSize: 线程池能够容纳同时执行的最大线程数,此值必须大于等于1
keepAliveTime: 多余的空闲线程的存活时间————当前线程数量超过corePoolSize时,当空闲时间达到keepAliveTime时,多余的空闲线程会被销毁直到只剩下corePoolSize个线程为止
unit: keepAliveTime的单位
workQueue: 任务队列,被提交但尚未被执行的任务
threadFactory: 表示生成线程池中工作线程的线程工厂,用于创建线程,一般用默认的饥渴
handler: 拒绝策略,表示当队列满了并且工作线程大于等于线程池的最大线程数(maximumPoolSize)时如何来拒绝
posted @ 2021-11-15 19:43  kanaliya  阅读(26)  评论(0)    收藏  举报