线程的状态
- new 新建一个状态值但还未启动。
- Runable Ruanable 包括了操作系统的线程状态中的running和ready,也就是处于此状态底下的线程有可能正在运行或者正在等在CPU分配时间片。
- waitting 无线等待期: 处于这种情况下的线程不会被cpu分配时间片,他们要等待其他线程的显式唤醒才可以。
- 没有设置timeOut 参数的Object.wait()方法。
- 没有设置TimeOut参数的Thread.join()方法。
- LockSupport.park()方法。
- Timed waiting 限期等待: 处于这种状态的线程也不会被分配时间片。但是他无需其他线程唤醒,在一定的时间之后他们会被分配CPU执行的时间
- Thread.sleep
- Object.wait()设置了TimeOut
- Thread.join()设置了TimeOut
- LockSupport.parkNanous()
- LockSupport.parkUtil()
- blocked阻塞: 线程被阻塞了,阻塞状态和等待状态的区别在于,阻塞是在等待获取到一个排他锁而等待是在等待另一个线程的唤醒或者等待一段时间。这种一般会在使用sychronnized的时候会发生
- Terminated结束: 已终止线程的线程状态,线程已结束执行。
上面的描述了6种但是其中有两种都是等待所以说是5种状态值。但是runable 也有区分两种 running 和 ready。所以也可说是6种吧(但是在深入理解java虚拟机一书中有描述是5种)
线程池的状态
在java中线程池的实现的主类是通过ThreadPoolExcutor这个类来实现的,
线程池运行的状态,并不是用户显式设置的,而是伴随着线程池的运行,由内部来维护。线程池内部使用一个变量维护两个值:运行状态(runState)和线程数量 (workerCount)。在具体实现中,线程池将运行状态(runState)、线程数量 (workerCount)两个关键参数的维护放在了一起,如下代码所示
private static int runStateOf(int c) { return c & ~CAPACITY; } //计算当前运行状态
private static int workerCountOf(int c) { return c & CAPACITY; } //计算当前线程数量
private static int ctlOf(int rs, int wc) { return rs | wc; } //通过状态和线程数生成ctl
这篇文章主要说的是状态值所以说java线程池有一下几种状态值:
其生命周期转换如下入所示:
几种状态值的转换