ThreadPoolExecutor

客户端提交任务给ThreadPoolExecutor,ThreadPoolExecutor 用其所持有的线程执行任务, 使得提交任务的线程与执行任务的线程相分离。


ThreadPoolExecutor 静态结构

Worker 实现了Runable接口,持有一个从Thread工厂中获取的线程,Worker 被创建时,其所持有的线程被运行。如果Worker 创建时被给定一个任务,则先执行完给定的任务;假如Worker创建时没有被被给定任务或给定任务已经执行结束,其会循环到workQueue 中取任务并执行任务。当取任务时当前Worker被界定为空闲且过期,则Worker生命结束并被移出Pool.

workers 是存放线程的Pool

workQueue 当Pool中的线程数量大于corePoolSize时,将客户端提交的任务存放在此队列中。一个Worker空闲时会从该队列中取走一个任务,如果队列中没有任务,则pending work,直到队列中有任务。




处理任务

1,当前pool中线程数量 < corePoolSize,立即开启新线程执行新提交的任务。

2,当前pool中线程数量 >= corePoolSize 且 任务队列未满,将新提交的任务添加到任务队列中。

3,假如任务队列已满 且 当前pool中线程数量 < maximumPoolSize 立即开启新线程执行新提交的任务。

4,假如线程池状态不为Running或pool中线程数量 >= maximumPoolSize, 线程池会采用某一拒绝策略拒绝客户端提交的任务。

拒绝策略

线程池创建时可以显式的指定拒绝策略RejectedExecutionHandler,假如没有显式的指定,线程池会使用默认拒绝策略AbortPolicy。线程池内在定义了四种拒绝策略

CallerRunsPolicy

如果线程池状态为Running,直接用提交任务的线程执行Task, 否则不处理任务。不处理任务时,客户端view中任务成功提交了,但实际上任务没有被运行。

AbortPolicy

直接抛出异常

DiscardPolicy

丢弃任务,不做任何处理

DiscardOldestPolicy

如果线程池状态为Running,从任务队列中遗弃一个任务,并尝试重新提交任务

Worker生命周期

allowCoreThreadTimeOut=true 时,线程等待任务时间 大于keepAliveTime,空闲线程退出;allowCoreThreadTimeOut=false 且当前pool中线程数量 >= corePoolSize时,线程等待任务时间 大于keepAliveTime,空闲线程退出


ThreadPoolExecutor生命周期


SHUTDOWN 继续执行正在执行的任务和workQueue中的任务;不再接受新提交的任务;中断所有空闲线程,当allow core threads timedout 或 pool中线程数量大于等于corePoolSize 时被中断的线程退出;当workQueue中没有任务时,pool中的线程退出。
STOP 继续执行正在执行的任务和 清空 workQueue中的任务;不再创建新线程 ;不再接受新提交的任务;中断所有线程,当allow core threads timedout 或 pool中线程数量大于等于corePoolSize 时被中断的线程退出;terminate ThreadPoolExecutor。
TIDYING 不再接受新提交的任务workQueue中没有任务
TERMINATED 执行完termindated() 由 TIDYING状态转换到 TERMINATED


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值