Java EE初阶启程记04---线程的状态

🔥个人主页: 寻星探路

🎬作者简介:Java研发方向学习者

📖个人专栏:、《

⭐️人生格言:没有人生来就会编程,但我生来倔强!!!



目录

1、观察线程的所有状态

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

3、观察线程的状态和转移


1、观察线程的所有状态

线程的状态是⼀个枚举类型Thread.State

java 复制代码
 public class ThreadState {
     public static void main(String[] args) {
         for (Thread.State state : Thread.State.values()) {
             System.out.println(state);
         }
     }
 }

NEW:安排了工作,还未开始行动(创建了thread对象,但是还没start)

RUNNABLE:可工作的,又可以分成正在工作中和即将开始工作

BLOCKED:这几个都表示排队等着其他事情(特指由于锁引起的阻塞)

WAITING:这几个都表示排队等着其他事情(死等进入阻塞状态,join)

TIMED_WAITING:这几个都表示排队等着其他事情(带有超时时间的阻塞等待)

TERMINATED:工作完成了(操作系统内部的线程已经销毁了,但是 Thread 对象还在,线程的入口方法执行完毕)

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

大家不要被这个状态转移图吓到,我们重点是要理解状态的意义以及各个状态的具体意思。

还是我们之前的例⼦:

刚把李四、王五找来,还是给他们在安排任务,没让他们行动起来,就是NEW状态;

当李四、王五开始去窗口排队,等待服务,就进入到 RUNNABLE 状态。该状态并不表示已经被银行工作人员开始接待,排在队伍中也是属于该状态,即可被服务的状态,是否开始服务,则看调度器的调度;

当李四、王五因为一些事情需要去忙,例如需要填写信息、回家取证件、发呆一会等等时,进入BLOCKED 、 WATING 、 TIMED_WAITING 状态,至于这些状态的细分,我们以后再详解; 如果李四、王五已经忙完,为 TERMINATED 状态。

所以,之前我们学过的isAlive()方法,可以认为是处于不是NEW和TERMINATED的状态都是活着的。

3、观察线程的状态和转移

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

java 复制代码
public class ThreadStateTransfer {
    public static void main(String[] args) throws InterruptedException {
        Thread t = new Thread(() -> {
            for (int i = 0; i < 1000_0000; i++) {
            }
        }, "李四");

        System.out.println(t.getName() + ": " + t.getState());;
        t.start();
        while (t.isAlive()) {
            System.out.println(t.getName() + ": " + t.getState());;
        }
        System.out.println(t.getName() + ": " + t.getState());;
    }
}

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

java 复制代码
public static void main(String[] args) {
    final Object object = new Object();

    Thread t1 = new Thread(new Runnable() {
        @Override
        public void run() {
            synchronized (object) {
                while (true) {
                    try {
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
        }
    }, "t1");
    t1.start();

    Thread t2 = new Thread(new Runnable() {
        @Override
        public void run() {
            synchronized (object) {
                System.out.println("hehe");
            }
        }
    }, "t2");
    t2.start();
 }

使用jconsole可以看到t1的状态是TIMED_WAITING,t2的状态是BLOCKED

修改上面的代码,把t1中的sleep换成wait

java 复制代码
public static void main(String[] args) {
    final Object object = new Object();
    Thread t1 = new Thread(new Runnable() {
        @Override
        public void run() {
            synchronized (object) {
                try {
                    // [修改这⾥就可以了!!!!!] 
                    // Thread.sleep(1000);
                    object.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }, "t1");
        ...
}

使用jconsole可以看到t1的状态是WAITING

结论:

BLOCKED表示等待获取锁,WAITING和TIMED_WAITING表示等待其他线程发来通知

TIMED_WAITING线程在等待唤醒,但设置了时限;WAITING线程在无限等待唤醒

相关推荐
努力也学不会java2 小时前
【Java并发】揭秘Lock体系 -- 深入理解ReentrantLock
java·开发语言·人工智能·python·机器学习·reentrantlock
郝学胜-神的一滴2 小时前
QAxios研发笔记(一):在Qt环境下,构建Promise风格的Get请求接口
开发语言·c++·spring boot·qt·ajax·前端框架·软件工程
haokan_Jia2 小时前
【MyBatis-Plus 动态数据源的默认行为】
java·开发语言·mybatis
_院长大人_2 小时前
IDEA 实现SpringBoot热部署(HotSwap和DevTools混用)
java·spring boot·intellij-idea
小信丶3 小时前
Spring 6 的 @HttpExchange 注解:声明式 HTTP 客户端的现代化利器
java·spring·http
扫地的小何尚6 小时前
NVIDIA Dynamo深度解析:如何优雅地解决LLM推理中的KV缓存瓶颈
开发语言·人工智能·深度学习·机器学习·缓存·llm·nvidia
野犬寒鸦6 小时前
多级缓存架构:性能与数据一致性的平衡处理(原理及优势详解+项目实战)
java·服务器·redis·后端·缓存
yi碗汤园6 小时前
【一文了解】C#的StringSplitOptions枚举
开发语言·前端·c#
帧栈8 小时前
开发避坑指南(58):Java Stream 按List元素属性分组实战指南
java