自定义线程池Executors
来源:互联网 发布:godaddy 域名转出 编辑:程序博客网 时间:2024/06/06 03:55
在使用有界队列时,若有新的任务需要执行,如果线程池实际线程数小于corePoolSize,则优先创建线程,若大于corePoolSize,则会将任务加入队列,若队列已满,则在总线程数不大于maximumPoolSize的前提下,创建新的线程,若线程数大于maxmumPoolSize,则执行拒绝策略。或其他自定义方式。
无界的任务队列时:LinkedBlockingQueue.与有界队列相比,除非系统资源耗尽,否则无界的任务队列不存在任务入队失败的情况。当有新任务到来系统的线程数小于corePoolSize时,则新建线程执行任务。当达到corePoolSize后,就不会增加。若后续有新的任务加入,而有没有空闲的线程资源,则任务直接进入队列等待。若任务创建和处理的速度差异很大,无界队列会保持快速增长,直到耗尽系统内存。
JDK拒绝策略:
AbortPolicy:直接抛出异常组织系统正常工作
CallerRunsPolicy:只要线程池未关闭,该策略直接在调用者线程中,运行当前被丢弃的任务。
DiscardOldestPolicy:丢弃最老的一个请求,尝试再次提交当前任务。
DiscardPolicy:丢弃无法处理的任务,不给予任何处理。
如果需要自定义拒绝策略可以实现RejectedExecutionhandler接口。
0 0
- 自定义线程池Executors
- Java Executors(线程池)
- java Executors(线程池)
- Java Executors(线程池)
- Executors 和线程池
- Java Executors(线程池)
- Executors 与线程池
- Executors线程池--java
- 线程池 Executors 入门
- Java Executors(线程池)
- java Executors线程池
- Java线程池Executors
- 线程池 Executors
- Java Executors(线程池)
- Executors 线程池
- Java Executors(线程池)
- 线程池 Executors 入门
- Java Executors(线程池)
- 处理日期时间最全的一些方法
- TensorFlow 安装
- 在java中正确使用PostgreSQL大对象和字节流类型的姿势
- 牛客网--优雅的点,圆,整数坐标
- Angular2 开发环境的搭建和@angular/cli(angular-cli)安装中的一些问题。
- 自定义线程池Executors
- 一些路径问题
- Qt Creator 设置默认编码格式
- Codeforces Beta Round #10 D. LCIS,输出发方案,动态规划
- C++面试常见问题总结
- jQuery学习教程十二: jQuery
- 时间复杂度O(n)什么意思
- 使用filter实现网站的gzip压缩
- IntelliJ IDEA 使用心得与常用快捷键