0

0

Java中线程状态有哪些 图解线程生命周期的六种状态

冰火之心

冰火之心

发布时间:2025-06-12 22:12:01

|

672人浏览过

|

来源于php中文网

原创

java线程生命周期包含六种状态,分别是new、runnable、blocked、waiting、timed_waiting和terminated。1. new表示线程被创建但尚未启动;2. runnable表示线程已就绪或正在运行;3. blocked表示线程因等待锁而阻塞;4. waiting表示线程无限期等待其他线程操作;5. timed_waiting表示线程在指定时间内等待;6. terminated表示线程执行完毕或异常终止。理解这些状态有助于诊断并发问题并优化性能,例如通过jstack分析线程堆栈信息判断状态,同时避免死锁需破坏互斥、占有等待、不可剥夺或循环等待条件之一。

Java中线程状态有哪些 图解线程生命周期的六种状态

Java中的线程状态可以理解为线程在其生命周期中所处的不同阶段,从创建到消亡,线程会经历多种状态的转变。理解这些状态对于编写高效、稳定的并发程序至关重要。

Java中线程状态有哪些 图解线程生命周期的六种状态

解决方案

Java中线程状态有哪些 图解线程生命周期的六种状态

Java线程的生命周期包含六种状态:NEW(新建)、RUNNABLE(可运行)、BLOCKED(阻塞)、WAITING(等待)、TIMED_WAITING(定时等待)和TERMINATED(终止)。

立即学习Java免费学习笔记(深入)”;

Java中线程状态有哪些 图解线程生命周期的六种状态

Java线程状态详解:深入理解并发编程的基石

线程状态是理解Java并发编程的关键。不同的状态反映了线程与操作系统、锁、以及其他线程之间的交互情况。深入理解这些状态,能帮助我们更好地诊断并发问题,优化程序性能。

  • NEW (新建):线程被创建但尚未启动。此时线程对象已经存在,但尚未调用 start() 方法。

  • RUNNABLE (可运行):这是一个复合状态,包括了 READY (就绪) 和 RUNNING (运行中) 两种状态。READY状态表示线程已经准备好运行,等待CPU调度;RUNNING状态表示线程正在执行 run() 方法中的代码。由于操作系统调度的不确定性,线程在这两种状态之间切换是无法人为控制的。

  • BLOCKED (阻塞):线程在等待获取锁时进入阻塞状态。例如,当线程尝试进入一个被其他线程持有的 synchronized 块或方法时,就会进入 BLOCKED 状态。

  • WAITING (等待):线程无限期地等待另一个线程执行特定操作。进入 WAITING 状态的常见方式有:

    • 调用 Object.wait() 方法(不带超时参数)。
    • 调用 Thread.join() 方法(不带超时参数)。
    • 调用 LockSupport.park() 方法。

    线程可以通过以下方式退出 WAITING 状态:

    • notify()notifyAll() 方法唤醒。
    • 被中断(interrupt() 方法)。
    • Thread.join() 方法的等待时间结束。
  • TIMED_WAITING (定时等待):与 WAITING 状态类似,但线程会等待指定的时间。进入 TIMED_WAITING 状态的常见方式有:

    • 调用 Thread.sleep() 方法。
    • 调用 Object.wait(long timeout) 方法(带超时参数)。
    • 调用 Thread.join(long timeout) 方法(带超时参数)。
    • 调用 LockSupport.parkNanos(long nanos)LockSupport.parkUntil(long deadline) 方法。

    线程可以通过以下方式退出 TIMED_WAITING 状态:

    • 等待时间结束。
    • notify()notifyAll() 方法唤醒。
    • 被中断(interrupt() 方法)。
    • Thread.join() 方法的等待时间结束。
  • TERMINATED (终止):线程执行完毕或因异常而终止。此时线程已经结束生命周期,不能再次启动。

    IBM Watson
    IBM Watson

    IBM Watson文字转语音

    下载

如何使用jstack命令分析线程状态?

jstack 是一个非常有用的命令行工具,它可以打印出指定 Java 进程的线程堆栈信息。通过分析线程堆栈信息,我们可以了解线程当前的状态,以及线程正在执行的代码。这对于诊断死锁、线程阻塞等并发问题非常有帮助。

例如,要分析进程ID为1234的Java进程,可以执行以下命令:

jstack 1234

jstack 的输出会包含每个线程的堆栈信息,其中包括线程的状态。例如:

"Thread-1" #10 prio=5 os_prio=0 tid=0x00007f9b88888000 nid=0x1a03 waiting on condition [0x00007f9b87e7f000]
   java.lang.Thread.State: TIMED_WAITING (sleeping)
        at java.lang.Thread.sleep(Native Method)
        at com.example.MyThread.run(MyThread.java:10)
        at java.lang.Thread.run(Thread.java:745)

从上面的输出可以看出,线程 "Thread-1" 的状态是 TIMED_WAITING (sleeping),并且正在执行 Thread.sleep() 方法。

死锁是如何产生的?如何避免?

死锁是指两个或多个线程互相等待对方释放资源,导致所有线程都无法继续执行的现象。死锁的产生通常需要满足以下四个条件:

  1. 互斥条件:资源必须处于独占状态,即一次只能被一个线程持有。
  2. 占有且等待条件:线程已经持有一个资源,但又请求新的资源,并且在等待新资源的同时,不释放已经持有的资源。
  3. 不可剥夺条件:线程已经获得的资源,在未使用完之前,不能被其他线程强行剥夺。
  4. 循环等待条件:多个线程之间形成循环等待资源的关系。

要避免死锁,可以破坏上述任何一个条件。常见的避免死锁的方法有:

  • 避免嵌套锁:尽量避免在一个锁的范围内请求另一个锁。
  • 使用定时锁:使用 tryLock(long timeout, TimeUnit unit) 方法,在等待锁的时候设置超时时间,避免无限期等待。
  • 资源排序:为所有资源定义一个全局的顺序,线程按照顺序请求资源,避免循环等待。
  • 使用死锁检测工具:一些工具可以帮助检测死锁,例如 jconsole

线程状态转换图的实际应用:优化并发程序

理解线程状态转换图对于优化并发程序至关重要。例如,如果发现大量线程处于 BLOCKED 状态,可能意味着锁竞争激烈,需要优化锁的使用方式。如果发现线程频繁在 WAITING 和 RUNNABLE 状态之间切换,可能意味着线程需要等待的条件过于频繁,需要重新设计线程间的协作方式。

通过分析线程状态,我们可以更好地理解程序的并发行为,从而找到性能瓶颈,并进行优化。

代码示例:模拟线程状态转换

以下代码演示了线程在不同状态之间的转换:

public class ThreadStateDemo {

    private static final Object lock = new Object();

    public static void main(String[] args) throws InterruptedException {
        // NEW 状态
        Thread thread = new Thread(() -> {
            try {
                // RUNNABLE -> BLOCKED 状态
                synchronized (lock) {
                    System.out.println("Thread acquired lock.");
                    // RUNNABLE -> WAITING 状态
                    lock.wait();
                    System.out.println("Thread woke up.");
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        });

        System.out.println("Thread state: " + thread.getState()); // 输出 NEW

        thread.start(); // NEW -> RUNNABLE

        Thread.sleep(100);
        System.out.println("Thread state: " + thread.getState()); // 可能输出 RUNNABLE 或 BLOCKED

        // 唤醒线程
        synchronized (lock) {
            lock.notify();
        }

        Thread.sleep(100);
        System.out.println("Thread state: " + thread.getState()); // 可能输出 RUNNABLE

        thread.join(); // 等待线程结束
        System.out.println("Thread state: " + thread.getState()); // 输出 TERMINATED
    }
}

这段代码创建了一个线程,并演示了线程从 NEW 状态到 RUNNABLE 状态,再到 BLOCKED 状态,最后到 WAITING 状态的转换。通过运行这段代码,可以更直观地理解线程状态的转换过程。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

443

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

605

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

764

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

99

2025.12.01

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

48

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

93

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.1万人学习

Java 教程
Java 教程

共578课时 | 80.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号