线程池的拒绝策略

线程池的拒绝策略是在任务无法被接受执行时,线程池采取的一种处理方式。Java中的ThreadPoolExecutor提供了几种内置的拒绝策略,可以通过构造函数或setRejectedExecutionHandler方法进行设置。以下是常见的拒绝策略:

AbortPolicy(默认策略):

AbortPolicy是默认的拒绝策略,当任务无法被接受时,会抛出RejectedExecutionException异常。这是默认的策略,表明线程池已经饱和,不能接受新的任务。
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.AbortPolicy());
2.CallerRunsPolicy:

CallerRunsPolicy策略会将被拒绝的任务交给提交任务的线程来执行。这种策略不会抛出异常,而是将任务回退给调用者,由调用者自行处理。
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
3.DiscardPolicy:

DiscardPolicy策略会默默地丢弃无法处理的任务,不抛出异常,也不做任何处理。对于一些不太重要的任务,使用这个策略可能是一种合理的选择
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.DiscardPolicy());
4.DiscardOldestPolicy:

DiscardOldestPolicy策略会丢弃队列中最老的一个任务,然后尝试重新提交当前任务。
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.DiscardOldestPolicy());
自定义拒绝策略也是可能的,只需实现RejectedExecutionHandler接口并提供相应的处理逻辑。例如:

public class CustomRejectedExecutionHandler implements RejectedExecutionHandler {

    @Override
    public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
        // 自定义处理逻辑
        // ...
    }
}


// 使用自定义的拒绝策略
executor.setRejectedExecutionHandler(new CustomRejectedExecutionHandler());
选择合适的拒绝策略取决于应用程序的需求和性质。不同的策略适用于不同的场景,开发人员应根据实际情况进行选择。


原文链接:https://blog.csdn.net/NZC2237/article/details/135560277

posted on   往事随风、  阅读(73)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示