线程池 threadpoolexecutor 学习

本文详细介绍了线程池的各种状态及其转换过程,包括线程池的初始化、任务接收与处理等核心行为。针对不同状态,文章阐述了线程池如何响应新任务、处理队列中的任务及线程数量的变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程池状态

  在ThreadPoolExecutor中定义了一个volatile变量,另外定义了几个static final变量表示线程池的各个状态:

volatile int runState;
static final int RUNNING    = 0;
static final int SHUTDOWN   = 1;
static final int STOP       = 2;
static final int TERMINATED = 3;

 

   runState表示当前线程池的状态,它是一个volatile变量用来保证线程之间的可见性;

  下面的几个static final变量表示runState可能的几个取值。

  当创建线程池后,初始时,线程池处于RUNNING状态;

  如果调用了shutdown()方法,则线程池处于SHUTDOWN状态,此时线程池不能够接受新的任务,它会等待所有任务执行完毕;

  如果调用了shutdownNow()方法,则线程池处于STOP状态,此时线程池不能接受新的任务,并且会去尝试终止正在执行的任务;

  当线程池处于SHUTDOWN或STOP状态,并且所有工作线程已经销毁,任务缓存队列已经清空或执行结束后,线程池被设置为TERMINATED状态


RUNNING:可接收新任务,可执行等待队列里的任务SHUTDOWN:不可接收新任务,可执行等待队列里的任务STOP:不可接收新任务,不可执行等待队列里的任务,并且尝试终止所有在运行任务TIDYING:所有任务已经终止,执行terminated()TERMINATED:terminated()执行完成

调用execute将会根据线程池的情况创建Worker,可以归纳出下图四种情况:

总结一下 针对于 newFixedThreadpool

首先来一个任务,创建一个线程。

当线程数量等于corepoolsize的时候,任务加入到工作队列中。

当工作队列慢的时候,继续增加线程知道maxpoolsize.

当线程数量=maxpoolsize的时候,新来的线程有rejecthandler处理。


rejecthandler有四种策略,

1 直接抛出异常 2 直接丢弃任务 3 丢掉工作队列里面老的任务,接受处理新任务 4 由客户端的线程处理任务


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值