博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ThreadPoolExecutor详解
阅读量:6432 次
发布时间:2019-06-23

本文共 1091 字,大约阅读时间需要 3 分钟。

转自:

第四个构造器源码

 

corePoolSize:核心池的大小

默认情况下,在创建了线程池后,线程池中的线程数为0,当有任务来之后,就会创建一个线程去执行任务,当线程池中的线程数数目少于corePoolSize时,有新任务进来就新建一个线程,即使有的线程没事干,当线程池中的线程数目达到corePoolSize时,将到达的任务放在缓存队列中

可以理解为:队列没满时,线程最大并发数

maximumPoolSize:线程池最多线程数

表示在线程池中最多能创建多少个线程

可以理解为:队列满后,线程能够达到的最大并发数

keepAliveTime:空闲线程过多久被回收的时间限制

默认情况下,只有当线程池中的线程数大于corePoolSize时,keepAliveTime才会起作用,直到线程池中的线程数不大于corePoolSize

unit:keepAliveTime的时间单位

workQueue:阻塞队列,用来存放待执行的任务

工作队列的默认选项是 SynchronousQueue,它将任务直接提交给线程而不保持它们。在此,如果不存在可用于立即运行任务的线程,则试图把任务加入队列将失败,因此会构造一个新的线程。此策略可以避免在处理可能具有内部依赖性的请求集时出现锁。直接提交通常要求无界 maximumPoolSizes 以避免拒绝新提交的任务。

 

 

 

ArrayBlockingQueue(有界队列,基于数组,先进先出)

 

LinkedBlockingQueue(无界队列,基于链表,先进先出)

 

 

 

threadFactory:线程工厂,用来创建新线程

handler:饱和策略

当队列和线程池都满了(也就是说超过了maximumPoolSiz和workQueue),说明线程池处于饱和状态,那么必须采用一种策略来处理新任务

 

 

当然也可以根据具体场景需要实现RejectedExecutionHandler接口来自定义策略,如记录日志或持久化不能处理的任务

 

构造器的使用

 

 

newSingleThreadExecutor-->单线程线程池

 

 

newFixedThreadExecutor(n)-->固定数量线程池

 

 

newCacheThreadExecutor(推荐使用)-->缓存线程池

 

 

newScheduleThreadExecutor

大小无限制的线程池,支持定时和周期性的执行线程

 

 

常用方法之向线程池提交任务

提交不需要返回值的任务

 

提交需要返回值的任务

 

常用方法之关闭线程池

 

 

 

 

转载于:https://www.cnblogs.com/sharpest/p/10576371.html

你可能感兴趣的文章
如何精简企业主数据“裹脚布”
查看>>
Pointer on C
查看>>
& 号和管道符号(|)在不同场景下的使用方法
查看>>
curl 浏览器模拟请求实战
查看>>
多个VLAN中的vrrp备份组配置举例
查看>>
运维自动化之使用PHP+MYSQL+SHELL打造私有监控系统(六)
查看>>
interlib在tomcat7.0的安装
查看>>
水晶报表在大型WEB内部管理系统里的滑铁卢
查看>>
我的友情链接
查看>>
Git学习
查看>>
trove 基于 centos7 制作 mysql5.6 镜像
查看>>
结合i节点和数据块分析linux中软链接和硬链接的区别
查看>>
Heartbeat crm的配置
查看>>
Stream
查看>>
我的友情链接
查看>>
Windows Server 2012_Install_Guide
查看>>
ISA Server搭建站点对站点×××
查看>>
我的友情链接
查看>>
超大规模数据中心:给我一个用整机柜的理由先
查看>>
执行命令取出linux中eth0的IP地址
查看>>