自定义线程池
来源:互联网 发布:知乎 陈寅恪 成就 编辑:程序博客网 时间:2024/06/10 00:05
本文转载自:
线程池参数详解
线程池源码详解
准备工作:
- 根据ThreadPoolExecutor 的参数 ,走一遍线程池执行的流程.
- execute()执行流程图
- execute()执行流程:
1.当线程池小于corePoolSize时,新提交任务将创建一个新线程执行任务,即使此时线程池中存在空闲线程。
2.当线程池达到corePoolSize时,新提交任务将被放入workQueue中,等待线程池中任务调度执行
3.当workQueue已满,且maximumPoolSize>corePoolSize时,新提交任务会创建新线程执行任务
4.当提交任务数超过maximumPoolSize时,新提交任务由RejectedExecutionHandler处理 - 补充:
1.当线程池线程总数中超过corePoolSize大小,线程池会在空闲时间达到keepAliveTime时,关闭空闲线程
2.java 1.6 加入了allowCoreThreadTimeOut(true),允许线程数低于corePoolSize时,线程也因为空闲而终止
自定义线程池:
- 一般来讲,自定义ThreadPoolExecutor的参数就基本可以满足我们的需求.
- 自定义线程池的目的一般两种
自定义线程工厂Debug打印Log日志 ,自定义 RejectedExecutionHandler (线程超出maxmumPoolSize+workQueue 时的处理策略)
new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, new DebugThreadFactory(), new ThreadPoolExecutor.DiscardPolicy() );
RejectedExecutionHandler 的四种预定义策略:
(1) 默认的ThreadPoolExecutor.AbortPolicy 处理程序遭到拒绝将抛出运行时RejectedExecutionException;
(2) ThreadPoolExecutor.CallerRunsPolicy 线程调用运行该任务的 execute 本身。此策略提供简单的反馈控制机制,能够减缓新任务的提交速度
(3) ThreadPoolExecutor.DiscardPolicy 不能执行的任务将被删除;
(4) ThreadPoolExecutor.DiscardOldestPolicy 如果执行程序尚未关闭,则位于工作队列头部的任务将被删除,然后重试执行程序(如果再次失败,则重复此过程)。
阅读全文
0 0
- 自定义线程池(1)
- 自定义线程池(2)
- 自定义线程池(3)
- 自定义线程池代码
- 自定义线程池ThreadPool
- C# 自定义线程池
- 自定义线程池
- java自定义线程池
- java 自定义线程池
- 自定义java 线程池
- 自定义线程池ThreadPoolExecutor
- Android 自定义线程池
- 自定义线程池Executors
- python自定义线程池
- 自定义Java线程池
- 自定义c++线程池
- 自定义线程池
- 自定义线程池---ThreadPoolExecutor
- C语言的运算符
- ZooKeeper概述(转)
- Android视图绘制流程完全解析,带你一步步深入了解View(二)
- 2017 多校训练第二场 HDU 6055 Regular polygon
- gmock解决不支持右值引用的问题
- 自定义线程池
- 20170727mabitas
- java web学习
- 如何自定义分块导出大图
- JAVA中常量使用常量类或者常量接口,还是使用枚举的区别
- HDU 6055 (2017 多校训练赛2 1011)Regular polygon
- Android6.0权限
- codeforces 802K Send the Fool Further! (medium) 树形dp
- Quartz与Spring里面实现定时器