线程池参数和实践
2017-10-21 00:00
113 查看
摘要: 一直在用,总结一下,新手容易搞混,其实很简单的。
ThreadPoolExecutor
ThreadPoolExecutor(
int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory,
RejectedExecutionHandler handler)
1、放入线程池内的任务是顺序执行的吗?
可以顺序执行,也可以不顺序执行。这个可以配置,参数组合最终都能达到顺序的结果,但是最保险的就有一种。就是核心线程数配成1。任务总数不能超过队列长度。
2、能执行的最大任务:
workQueue.length+maximumPoolSize
3、超出后会执行handler对应处理,我们需要实现RejectedExecutionHandler接口,在该实现内,做出一些针对线程不够用错误处理。
4、我们需要实现ThreadFactory,来生成一个Thread工厂,该工厂内的线程,需要根据业务进行定制化,是否设置成后台线程、线程名字根据业务自定义等等
最后:使用起来,我们需要根据实际情况进行参数的组合,用多了就知道怎么配置最适合自己业务的线程池了。
ThreadPoolExecutor
ThreadPoolExecutor(
int corePoolSize,
int maximumPoolSize,
long keepAliveTime,
TimeUnit unit,
BlockingQueue<Runnable> workQueue,
ThreadFactory threadFactory,
RejectedExecutionHandler handler)
1、放入线程池内的任务是顺序执行的吗?
可以顺序执行,也可以不顺序执行。这个可以配置,参数组合最终都能达到顺序的结果,但是最保险的就有一种。就是核心线程数配成1。任务总数不能超过队列长度。
2、能执行的最大任务:
workQueue.length+maximumPoolSize
3、超出后会执行handler对应处理,我们需要实现RejectedExecutionHandler接口,在该实现内,做出一些针对线程不够用错误处理。
4、我们需要实现ThreadFactory,来生成一个Thread工厂,该工厂内的线程,需要根据业务进行定制化,是否设置成后台线程、线程名字根据业务自定义等等
最后:使用起来,我们需要根据实际情况进行参数的组合,用多了就知道怎么配置最适合自己业务的线程池了。
相关文章推荐
- Java 线程池的理论与实践
- 对/proc/cpuinfo文件下的各个参数的说明及实践
- Java线程池使用和常用参数
- 第12周OJ实践 利用参数宏进行角度与弧度转换
- JavaScript 函数参数的最佳实践
- 记一次解决非法参数DDoS攻击的实践
- Linux多线程实践(9) --简单线程池的设计与实现
- OMA DM最佳实践之三:参数采集
- jfinal 实现注解参数拦截实践
- sqlite3_prepare_v2 最后参数的实践
- GDB调试带参数的程序(转载+整理+实践)
- 线程池ThreadPoolExecutor参数设置
- ThreadPoolExecutor线程池参数设置技巧
- 【python】研究与实践 python线程池爬取某网的接口视频资源入库
- JVM理论与实践【JVM参数调优】
- JVM性能参数调优实践,不会执行Full GC,网站无停滞
- 详解tomcat线程池原理及参数释义
- Java Executor并发框架(四)创建线程池的核心参数的解释
- Java 理论与实践: 线程池与工作队列
- 各类操作系统做Web Server 内核参数调整实践