Java线程池、拒绝策略

ThreadPoolExecutor构造器

```java /** * The default rejected execution handler */ private static final RejectedExecutionHandler defaultHandler = new AbortPolicy();

public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue 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 | 由调用线程(当前提交任务的线程)处理该任务 | 不抛出异常,任务仍然执行 |

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值