多线程(五)线程状态
一、操作系统层面五种状态
- 【初始状态】仅是在语言层面创建了线程对象,还未与操作系统线程关联
常见的创建了线程,还没有start()就属于这种状态
- 【可运行状态】(就绪状态)指该线程已经被创建(与操作系统线程关联),可以由 CPU 调度执行
常见的运行了start()等待cpu分配时间片就属于这种状态
- 【运行状态】指获取了 CPU 时间片运行中的状态
当 CPU 时间片用完,会从【运行状态】转换至【可运行状态】,会导致线程的上下文切换
- 【阻塞状态】
如果调用了阻塞 API,如 BIO 读写文件,这时该线程实际不会用到 CPU,会导致线程上下文切换,进入【阻塞状态】
等 BIO 操作完毕,会由操作系统唤醒阻塞的线程,转换至【可运行状态】
与【可运行状态】的区别是,对【阻塞状态】的线程来说只要它们一直不唤醒,调度器就一直不会考虑调度它们
- 【终止状态】表示线程已经执行完毕,生命周期已经结束,不会再转换为其它状态
二、JAVA API层面的六种线程状态
根据 Thread.State 枚举,分为六种状态
-
【NEW】 线程刚被创建,但是还没有调用 start() 方法
-
【RUNNABLE】 当调用了 start() 方法之后,注意,Java API 层面的 RUNNABLE 状态涵盖了 操作系统 层面的【可运行状态】、【运行状态】和【阻塞状态】(由于 BIO 导致的线程阻塞,在 Java 里无法区分,仍然认为是可运行)
-
【BLOCKED】 , 【WAITING】 ,【TIMED_WAITING】 都是 Java API 层面对【阻塞状态】的细分,后面会在状态转换一节详述
这里简单介绍一下这三个状态,有些知识需要后续内容支撑。
Java文档官方定义BLOCKED状态是:“这种状态是指一个阻塞线程在等待monitor锁。”
其实就是没有能拿到锁的线程(在entryList里面的线程)的状态。
Java文档官方定义WAITING状态是:“一个线程在等待另一个线程执行一个动作时在这个状态”
就是没有时间限制的线程等待状态,常见的执行以下方法后
Object.wait() 而且不加超时参数
Thread.join() 而且不加超时参数
LockSupport.park()
都是waiting状态
Java文档官方定义TIMED_WAITING状态为:“一个线程在一个特定的等待时间内等待另一个线程完成一个动作会在这个状态”
就是有时间限制的线程等待状态,常见的执行以下方法后
Thread#sleep()
Object#wait() 并加了超时参数
Thread#join() 并加了超时参数
LockSupport#parkNanos()
LockSupport#parkUntil()
都是timed_waiting状态
- TERMINATED 当线程代码运行结束
参考文献:
BLOCKED,WAITING,TIMED_WAITING有什么区别?
AITING有什么区别?](https://blog.csdn.net/liweiminlining/article/details/102490259)