本文主要是介绍面试题:线程有哪几种状态以及各种状态之间的转换?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
线程在其生命周期中可以经历多种状态,不同资料来源可能给出略微不同的状态划分,但大体上可以概括为以下几种主要状态及它们之间的转换:
-
新建状态(New):
- 当使用
new
关键字创建一个线程对象后,线程就处于新建状态。此时,线程还未开始执行,仅在 JVM 中分配了内存,并初始化了成员变量。
- 当使用
-
可运行状态(Runnable):
- 当调用线程的
start()
方法后,线程进入可运行状态。此状态又可以细分为两种:- 就绪状态:线程已经准备好运行,等待CPU调度执行。
- 运行状态:线程获得CPU时间片并正在执行。需要注意的是,Java文档有时将就绪和运行统称为“Runnable”状态。
- 当调用线程的
-
阻塞状态(Blocked):
- 线程在运行过程中,由于某种原因(如等待I/O操作完成、试图获取某个锁而被阻塞、调用
wait()
方法等)暂停执行,进入阻塞状态。在此状态下,线程不会消耗CPU时间。
- 线程在运行过程中,由于某种原因(如等待I/O操作完成、试图获取某个锁而被阻塞、调用
-
等待状态(Waiting):
- 线程主动放弃CPU执行权,进入无限期等待状态,直到被其他线程通过特定操作(如
notify()
或notifyAll()
)唤醒。这包括调用Object.wait()
、Thread.join()
无参方法或LockSupport.park()
等情况。
- 线程主动放弃CPU执行权,进入无限期等待状态,直到被其他线程通过特定操作(如
-
超时等待状态(Timed Waiting):
- 类似于等待状态,但线程不是无限等待,而是设置了等待的超时时间。例如,调用
Thread.sleep(long millis)
、Object.wait(long timeout)
、Thread.join(long millis)
或LockSupport.parkNanos(long nanos)
等方法后,线程会在指定时间后自动醒来。
- 类似于等待状态,但线程不是无限等待,而是设置了等待的超时时间。例如,调用
-
死亡状态(Terminated/Dead):
- 线程执行完毕(即
run()
方法结束),或者因抛出未捕获的异常而提前结束,线程进入死亡状态,不再参与调度。
- 线程执行完毕(即
状态转换图概述:
- 新建状态 -> 可运行状态:调用
start()
方法。 - 可运行状态 -> 阻塞状态:等待资源(如锁)。
- 可运行状态 -> 等待/超时等待状态:调用相应的等待方法。
- 阻塞/等待/超时等待状态 -> 可运行状态:等待条件满足,如获得锁、被唤醒、等待时间到期等。
- 可运行状态 -> 死亡状态:
run()
方法执行完毕或异常终止。
这篇关于面试题:线程有哪几种状态以及各种状态之间的转换?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!