news 2026/4/3 3:07:42

Java 线程状态详解:从观察到理解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java 线程状态详解:从观察到理解

一、观察线程的所有状态

在 Java 中,线程的状态是由 Thread.State 枚举定义的,一共有 6 种状态。这些状态代表了线程从创建到销毁的各个阶段。我们可以通过 Thread.getState() 方法来获取当前线程的状态。

以下是所有线程状态的列表:

  • NEW:线程刚刚创建,但尚未启动(调用 start() 方法之前)。
  • RUNNABLE:线程已经启动,正在执行或等待 CPU 调度。这包括线程在运行或就绪状态。
  • BLOCKED:线程正在等待监视器锁(monitor lock),通常发生在进入 synchronized 块或方法时被阻塞。
  • WAITING:线程正在无限期等待另一个线程的特定操作,例如调用 Object.wait()、Thread.join() 或 LockSupport.park()。
  • TIMED_WAITING:类似于 WAITING,但有时间限制,例如调用 Thread.sleep()、Object.wait(long timeout) 或 Thread.join(long millis)。
  • TERMINATED:线程执行完成或异常退出,已结束生命周期。

二、线程状态和状态转移的意义

状态转移的意义:

  • NEW → RUNNABLE:调用 thread.start()。意义:启动线程,进入可执行状态。这是线程“出生”的关键一步。
  • RUNNABLE → BLOCKED:尝试获取已被占用的锁。意义:体现了互斥访问的必要性,避免数据竞争。
  • RUNNABLE → WAITING:调用 wait()、join() 等。意义:实现线程协作,如生产者-消费者模式。
  • RUNNABLE → TIMED_WAITING:调用 sleep() 或带时限的 wait()。意义:引入时间维度,适用于延迟执行或超时机制。
  • BLOCKED → RUNNABLE:获取到锁。意义:阻塞结束,继续执行。
  • WAITING/TIMED_WAITING → RUNNABLE:收到 notify()、超时或中断。意义:唤醒机制,确保线程不会永久卡住。
  • RUNNABLE → TERMINATED:run() 方法执行完毕或抛出未捕获异常。意义:正常或异常结束,释放资源。

三、观察线程的状态和

观察 1:关注 NEW 、 RUNNABLE 、 TERMINATED 状态的转换

public class Observation1 { public static void main(String[] args) throws InterruptedException { // 创建线程 (NEW 状态) Thread simpleThread = new Thread(() -> { System.out.println("Thread is running... Doing some work."); // 模拟工作,结束后自然进入 TERMINATED }); // 观察 NEW 状态 System.out.println("State after creation: " + simpleThread.getState()); // NEW // 启动线程 (NEW -> RUNNABLE) simpleThread.start(); Thread.sleep(100); // 短暂等待,确保线程进入 RUNNABLE System.out.println("State after start: " + simpleThread.getState()); // RUNNABLE // 等待线程结束 (RUNNABLE -> TERMINATED) simpleThread.join(); System.out.println("State after termination: " + simpleThread.getState()); // TERMINATED } }

观察 2:关注 WAITING 、 BLOCKED 、 TIMED_WAITING 状态的转换

public class Observation2 { private static final Object lock = new Object(); public static void main(String[] args) throws InterruptedException { // 创建工作者线程 Thread workerThread = new Thread(() -> { try { // 进入 TIMED_WAITING (sleep) System.out.println("Entering TIMED_WAITING via sleep..."); Thread.sleep(1000); // 进入 WAITING (wait) synchronized (lock) { System.out.println("Entering WAITING via wait..."); lock.wait(); } // 模拟工作结束 System.out.println("Worker thread resuming after notify."); } catch (InterruptedException e) { Thread.currentThread().interrupt(); } }); // 创建阻塞模拟线程:先占用锁 Thread blockerThread = new Thread(() -> { synchronized (lock) { try { System.out.println("Blocker holding lock for 2 seconds..."); Thread.sleep(2000); // 占用锁,迫使其他线程 BLOCKED } catch (InterruptedException e) { Thread.currentThread().interrupt(); } } }); // 启动 blocker 先占用锁 blockerThread.start(); Thread.sleep(100); // 确保 blocker 先运行 // 启动 worker (进入 RUNNABLE) workerThread.start(); Thread.sleep(100); System.out.println("Worker state after start: " + workerThread.getState()); // RUNNABLE // 观察 TIMED_WAITING (sleep) Thread.sleep(500); System.out.println("Worker state during sleep: " + workerThread.getState()); // TIMED_WAITING // 等待 sleep 结束,worker 尝试 wait,但需先获取锁(可能 BLOCKED) Thread.sleep(1000); System.out.println("Worker state when trying to acquire lock for wait: " + workerThread.getState()); // BLOCKED (如果 blocker 还在占用) // 等待 blocker 释放锁,worker 进入 WAITING Thread.sleep(1500); System.out.println("Worker state during wait: " + workerThread.getState()); // WAITING // 唤醒 worker (WAITING -> RUNNABLE) synchronized (lock) { lock.notify(); } Thread.sleep(100); System.out.println("Worker state after notify: " + workerThread.getState()); // RUNNABLE 或 TERMINATED // 等待结束 workerThread.join(); blockerThread.join(); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/3 4:50:58

Dify Tesseract 静默更新是如何做到的?一线架构师亲授底层实现逻辑

第一章:Dify Tesseract 的更新机制Dify Tesseract 作为一款集成 AI 工作流与自动化任务调度的开源平台,其更新机制设计兼顾稳定性与灵活性。系统采用基于 Git 的版本控制策略,结合 Webhook 触发自动部署流程,确保代码变更能够快速…

作者头像 李华
网站建设 2026/3/23 4:00:06

从“制造”到“智造”:Linux数控系统的核心优势

在竞争日益激烈的制造业中,两个核心诉求始终萦绕在每一位工厂管理者心头:如何把零件做得更精准?如何对生产过程了如指掌? 传统数控系统或许能完成基本任务,但在面对超高精度需求和“加工黑盒”问题时,往往力…

作者头像 李华
网站建设 2026/4/1 13:56:39

路灯不再“盲目”亮:Linux控制器实现按需照明

在无数个深夜里,城市的路灯如同忠实的哨兵,默默照亮着归家的路。然而,一个长期存在的浪费现象却常常被我们忽略:在车流稀疏的后半夜,这些路灯依然以白天的全功率状态照耀着空旷的街道。这不仅消耗着巨大的电能&#xf…

作者头像 李华
网站建设 2026/3/13 20:02:08

Spring AI对接Dify的10个关键步骤,99%开发者忽略的部署细节

第一章:Spring AI对接Dify的核心架构解析在构建智能化企业级应用的过程中,Spring AI 与 Dify 的集成正成为连接传统后端服务与现代大模型能力的关键桥梁。该架构以 Spring Boot 应用为运行主体,通过标准化的 API 客户端与 Dify 提供的开放接口…

作者头像 李华