线程池
2022-03-17 本文已影响0人
意大利大炮
ThreadPoolExecutor参数
参数 | 定义 | 说明 |
---|---|---|
corePooleSize | 核心线程数量 | 核心线程默认不会关闭,除非设置了 allowCoreThreadTimeOut = 1; |
maximumPoolSize | 最大线程数量 | 注意,只有当workQueue满时,才会创建核心线程外不大于maximumPoolSize数量的线程 |
keepAlivceTime | 线程空闲时保留时间 | 默认当线程数大于核心,这是多余的空闲线程会等待新的任务终止前的最大时间。 |
unit | keepAliveTime的时间单位 | 配合keepAlivceTime 使用 |
workQueue | 在任务执行之前用来保存任务的队列 | |
handler | 拒绝策略 |
execute方法
- 如果运行的线程少于corePoolSize,则尝试用给定的命令作为第一个命令启动一个新线程的任务。调用addWorker会自动检查runState和workerCount,这样可以防止误报线程,当它不应该返回false。
- 如果一个任务可以成功排队,那么我们仍然需要再次检查我们是否应该添加一个线程(因为现有的已经在上次检查后死亡)或其他进入此方法后池关闭。所以我们如果需要,请重新检查状态并回滚排队停止,或者启动一个新的线程(如果没有)。
- 如果不能对任务进行排队,则尝试添加一个新的线程。如果它失败了,我们知道我们已经关闭或饱和了所以拒绝这个任务。