登录
首页 >  文章 >  java教程

Java线程状态及转换全解析

时间:2026-04-14 19:58:32 476浏览 收藏

Java线程的六大状态(NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING、TERMINATED)并非理论抽象,而是JVM中真实可读、可追踪的生命周期快照,精准反映线程在操作系统调度与Java并发机制共同作用下的实际行为;其中RUNNABLE是唯一能执行代码的“活跃态”,其余状态则揭示了线程因未启动、争锁、被动等待或超时休眠等不同原因而暂停的本质差异——深入理解这些状态及其转换逻辑,不仅能破除常见误区(如误以为RUNNABLE一定在运行),更是定位死锁、线程假死和性能瓶颈的关键突破口。

在Java中什么是线程状态_Java线程六大状态的转换逻辑说明

Java线程状态是描述线程在其生命周期中所处阶段的枚举值,共六种:NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING、TERMINATED。它们不是抽象概念,而是Thread类中可直接通过getState()读取的真实状态,反映线程在JVM和操作系统调度下的真实行为。

NEW:刚建好还没开工

线程对象已创建,但start()方法尚未调用。

  • 此时isAlive()返回false
  • 可以设置名称、优先级、守护属性等,但不能执行任何任务逻辑
  • 状态不可逆——一旦调用start(),立刻离开NEW,且不能再回到该状态

RUNNABLE:能跑,不等于正在跑

这是最易误解的状态。它包含两个实际情形:就绪(READY)和运行中(RUNNING)。

  • 线程已调用start(),被纳入JVM线程调度队列
  • 可能正占用CPU执行代码,也可能在等待CPU时间片分配
  • IO阻塞、锁竞争、sleep超时、wait被唤醒后,都会重新进入RUNNABLE
  • 注意:synchronized未抢到锁时不会进RUNNABLE,而是进BLOCKED

BLOCKED、WAITING、TIMED_WAITING:三种“卡住”方式不同

它们都表示线程暂停执行,但触发原因和恢复机制完全不同:

  • BLOCKED:等着进synchronized块或方法,因锁被其他线程持有而挂起(比如两个线程争同一把对象监视器)
  • WAITING:调用Object.wait()Thread.join()LockSupport.park()后无限期等待,必须靠其他线程显式唤醒
  • TIMED_WAITING:调用Thread.sleep(n)Object.wait(n)Thread.join(n)LockSupport.parkNanos()等带超时参数的方法,时间一到或被唤醒即恢复

TERMINATED:任务结束,生命终结

线程run()方法正常执行完毕,或因未捕获异常而提前退出,就会进入此状态。

  • 一旦到达TERMINATED,状态不可变,也不能再次start()
  • 即使线程对象还存在(引用未被回收),它也不再是活动线程
  • 可通过isAlive() == false粗略判断,但更准确的是getState() == TERMINATED

基本上就这些。状态转换围绕RUNNABLE展开,它是唯一能主动发起计算的“活跃态”,其余五种都是它的临时停留点。理解每种卡住的原因,是排查死锁、活锁、假死问题的关键。

到这里,我们也就讲完了《Java线程状态及转换全解析》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>