栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【JavaEE】java线程的几种状态

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【JavaEE】java线程的几种状态

我们先来看看Java线程状态的一幅图:

  • 1. New状态:初始状态,即安排了工作, 还未开始行动;
  • 2. Runnable状态:运行状态,这面还包含了就绪,运行等状态;
  • 3. Waiting状态:等待状态,就是在等待运行;
  • 4. Time_Waiting状态:超时等待,就是在等待运行;
  • 5. Blocked状态:阻塞状态,就是在等待运行;
  • 6. Terminated状态:终止状态。工作完成了。

我们经过对线程的学习,我们对他的运行状态图和他的几种状态已经很熟悉了。那他么之间如何转换呢?

1. 关注 NEW 、 RUNNABLE 、 TERMINATED 状态的转换

// 使用 isAlive 方法判定线程的存活状态
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 状态的转换

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();
}

结论:
BLOCKED 表示等待获取锁, WAITING 和 TIMED_WAITING 表示等待其他线程发来通知.
TIMED_WAITING 线程在等待唤醒,但设置了时限; WAITING 线程在无限等待唤醒

3: yield() 大公无私,让出 CPU
 

Thread t1 = new Thread(new Runnable() {
    @Override
    public void run() {
        while (true) {
            System.out.println("张三");
        // 先注释掉, 再放开
        // Thread.yield();
        }
    }
}, "t1");
t1.start();
Thread t2 = new Thread(new Runnable() {
    @Override
    public void run() {
        while (true) {
            System.out.println("李四");
        }
    }
}, "t2");
t2.start();
// 结果
// 不使用 yield 的时候, 张三李四大概五五开
// 使用 yield 时, 张三的数量远远少于李四

结论:
yield 不改变线程的状态, 但是会重新去排队.

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/852064.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号