多线程之四大拒绝策略
来源:互联网 发布:js加载本地json文件 编辑:程序博客网 时间:2024/06/06 01:00
定义拒绝策略,需要重写RejectedExecutionHandler接口的rejectedExecution(Runnable r, ThreadPoolExecutor executor);方法。
public interface RejectedExecutionHandler { void rejectedExecution(Runnable r, ThreadPoolExecutor executor);}
AbortPolicy策略
该策略直接抛出异常。
public static class AbortPolicy implements RejectedExecutionHandler { public AbortPolicy() { public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { throw new RejectedExecutionException("Task " + r.toString() + " rejected from " + e.toString()); } }
注意:使用此拒接策略,切记ThreadPoolExecutor.execute需要try catch,否则程序会直接退出。
CallerRunsPolicy策略
public static class CallerRunsPolicy implements RejectedExecutionHandler { public CallerRunsPolicy() { } public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { if (!e.isShutdown()) { r.run(); } } }
从源码可以看出:只要线程池未关闭,该策略直接在调用者线程(如Main方法)中运行当前被丢弃的任务。显然这样不会真的丢弃任务,但是,调用者线程性能可能急剧下降。
DiscardPolicy策略
public static class DiscardPolicy implements RejectedExecutionHandler { public DiscardPolicy() { } public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { } }
默默的丢弃无法处理的任务,不予任何处理。
DiscardOldestPolicy策略
丢弃最老的一个请求任务,也就是丢弃一个即将被执行的任务,并尝试再次提交当前任务。
public static class DiscardOldestPolicy implements RejectedExecutionHandler { public DiscardOldestPolicy() { } public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { if (!e.isShutdown()) { e.getQueue().poll(); e.execute(r); } } }
一般在实际开发中,根据业务需求,自定义拒绝策略。
阅读全文
0 0
- 多线程之四大拒绝策略
- 线程池之拒绝策略
- java多线程-ThreadPoolExecutor的拒绝策略RejectedExecutionHandler
- 简化设计之四大策略
- 多线程之策略模式
- Threadpool拒绝策略
- 线程池拒绝策略
- 四大交易策略
- 多线程之linux线程调度策略
- Java多线程之锁优化策略
- 多线程之四大线程池的使用介绍
- 文件被数字签名策略拒绝
- 有效的四大SEO策略
- iOS 多线程同步策略之-----锁NSLock和@synchronized
- GCD之Apple推崇的多线程管理策略
- 设置IP策略拒绝用户Ping服务器
- 线程池的生命周期和拒绝策略
- 《Java线程池》:任务拒绝策略
- Web前端技术 自学or老师授课更靠谱
- go 输出程序奔溃日志
- CodeIgniter框架源码学习之数据库类--DB.php
- 游戏家?腾讯王者荣耀全球吸金,转头又要打造新概念
- es6学习第一篇(let和const命令)
- 多线程之四大拒绝策略
- error: ORA-01034:oracle not available ORA-27101:shared memory realm does not exist
- 字符串的遍历
- best-time-to-buy-and-sell-stock Java code
- freemark生成CURD模板
- H6机顶盒Android编译[2]-Android编译
- gprof使用介绍
- JAVA知识_10
- <c++>循环语句