线程池---ThreadPoolExecutor中corePoolSize,maximumPoolSize,workQueue的关系
来源:互联网 发布:淘宝返现在哪里查看 编辑:程序博客网 时间:2024/06/06 19:58
常见的线程池创建方法有四种,但是这4中最终都会调用同一种创建方式:
public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit, BlockingQueue<Runnable> workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handler);这里只解释corePoolSize,maximumPoolSize,workQueue,其它变量比较好理解。
例子:
ThreadPoolExecutor executor = new ThreadPoolExecutor(5, 10, 200, TimeUnit.MILLISECONDS, new ArrayBlockingQueue<Runnable>(5));,后面两个变量会设置默认值。
从上面可知:
corePoolSize=5,maximumPoolSize=10,workQueue的size是5。
打个比方,现在5个工人(corePoolSize,车间正常工作工位只有5个)正在一个房子(maxPoolSize最多容纳10个人一起工作,但是会很挤)里加工机器,另外有一个房子里面能存放机器的最大容量是5(对应workQueue的size,5台),如果老板在买的机器在五台以内,这5个工人能依次从仓库中去5台出来加工,此时仓库的5台机器就被拿出来了,仓库是空的;
超过5个并且小于10个,那么此时工人在工作(5台机器正在被加工),仓库还可以放机器;
超过是10个但是小于15个(maxPoolSize+workQueue.size),假设n个,老板在会再安排n-10个人到车间去帮忙,最多增加5个人;
超过15个,车间人挤不下了,仓库也放满了,可能会报异常,这取决于RejectedExecutionHandler 的机制选择了。
阅读全文
0 0
- 线程池---ThreadPoolExecutor中corePoolSize,maximumPoolSize,workQueue的关系
- ThreadPoolExecutor的corePoolSize和maximumPoolSize
- ThreadPoolExecutor的corePoolSize和maximumPoolSize
- 理解ThreadPoolExecutor源码(一)线程池的corePoolSize、maximumPoolSize和poolSize
- 理解ThreadPoolExecutor源码(一)线程池的corePoolSize、maximumPoolSize和poolSize
- java中ThreadPoolExecutor线程池的使用
- 使用ThreadPoolExecutor,当提交线程超过maximumPoolSize 会阻塞主线程吗?
- JAVA自带线程池和线程池中包含的workQueue。
- ThreadPoolExecutor线程池的getActiveCount
- ThreadPoolExecutor线程池的使用
- 线程池ThreadPoolExecutor的使用
- 线程池ThreadPoolExecutor的使用方法
- 线程池ThreadPoolExecutor的原理
- ThreadPoolExecutor线程池的使用
- spring 线程池配置(corePoolSize,maxPoolSize,queueCapacity,keepAliveSeconds,rejectedExecutionHandler)
- ThreadPoolExecutor中运行线程名称的修改
- Java多线程研究05-ThreadPoolExecutor中workQueue、threadFactory和handle
- Spring中配置线程池ThreadPoolExecutor参考
- 类型转换
- linux初学者-磁盘阵列篇
- 326. Power of Three
- 深入理解const char*p,char const*p,char *const p,const char **p,char const**p,char *const*p,char**const
- 聚类和分类
- 线程池---ThreadPoolExecutor中corePoolSize,maximumPoolSize,workQueue的关系
- 最大连续子序列和
- 人脸识别算法初次了解
- oracleday08(桥直连)
- HTTP详解(二):HTTP报文格式
- Class.newInstance()
- C++ 实时获取CPU使用率的类 (源码)
- Apache简介
- Oracle12c 容灾切换完全步骤