ThreadPoolExecutor构造器
/**
* The default rejected execution handler
*/
private static final RejectedExecutionHandler defaultHandler = new AbortPolicy();
public ThreadPoolExecutor(int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue) {
this(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue,
Executors.defaultThreadFactory(), defaultHandler);
}
参数 | 含义 | 备注 |
---|---|---|
corePoolSize | 核心线程数量,线程池初始化时定义 | 如果corePoolSize==maximumPoolSize,则线程池中线程不会空闲,keepAliveTime就不再有作用。 |
maximumPoolSize | 最大线程数;核心线程与非核心线程共同使用线程池,但核心线程不会被回收。 | |
keepAliveTime | 保持时间:若目前线程数>核心线程数,多余线程在等待keepAliveTime时间后未进行任务,则会被回收。 | |
unit | keepAliveTime的时间单位 | |
workQueue | 等待队列 | |
defaultHandler | 拒绝策略 | AbortPolicy(默认):直接抛弃 |
异常产生原因
当线程池里的线程都繁忙的时候,新任务会被提交给阻塞队列保存,当提交给阻塞队列的任务,超出了该队列的最大容量时。线程池就会拒绝接收新任务,随即抛出异常。
四种拒绝策略
策略名称 | 含义 | 备注 |
---|---|---|
AbortPolicy | 当队列满时抛出RejectExecutionException异常,可捕捉后自行处理 | 默认策略 通过异常可及时发现系统无法承载的并发 |
DiscardPolicy | 默默丢弃任务,不抛出异常 | 无法发现系统的异常状态,且影响业务(对于阅读量统计的低重要性的场景可使用) |
DiscardOldestPolicy | 丢弃队列中最前的任务,重新提交被拒绝的任务 | “喜新厌旧”策略 |
CallerRunsPolicy | 由调用线程(当前提交任务的线程)处理该任务 | 不抛出异常,任务仍然执行 |