并发编程

并发编程(三):线程状态

2020-04-03  本文已影响0人  codeMover

线程状态

线程五种状态

image.png
  1. 【初始状态】仅在语言层面创建了线程,还未与操作系统线程关联
  2. 【可运行状态(就绪状态)】该线程已经被创建(与操作系统线程关联),可以由CPU调度执行
  3. 【运行状态】获取了CPU时间片,线程RUN方法代码在执行
  1. 【阻塞状态】
  1. 【终止状态】表示线程已经执行完毕,生命周期已经结束,不会再装换为其他状态

线程六种状态

  1. NEW 线程刚被创建,但是还没有调用start()方法
  2. RUNNABLE 当调用了start()之后,Java API层面的RUNNABLE状态涵盖了操作系统层面的【可运行状态】、【运行状态】、【阻塞状态】(由于BIO导致的线程阻塞,在Java里无法区分,仍然认为是可运行)
  3. BLOCKED
  4. WAITING
  5. TIMED_WAITING
  6. TERMINATED 线程执行完毕,生命周期已经结束,不会再装换为其他状态
@Slf4j(topic = "ants.TestThreadState")
public class TestThreadState {
    public static void main(String[] args) throws InterruptedException {
        Thread t1 = new Thread("t1") {
            @Override
            public void run() {
                log.debug("t1 running");//只是新建对象,这是状态是NEW
            }
        };

        Thread t2 = new Thread("t2") {
            @Override
            public void run() {
                while (true){
                    //线程可运行、线程运行以及IO操作都会是RUNNABLE状态
                }
            }
        };
        t2.start();

        Thread t3 = new Thread("t3") {
            @Override
            public void run() {
                log.debug("t3 running");//执行完,线程状态是TERMINATED
            }
        };
        t3.start();

        Thread t4 = new Thread("t4") {
            @Override
            public void run() {
                synchronized (TestThreadState.class){
                    try {
                        Thread.sleep(10000000);//TIMED_WAITING,有时限等待
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
        };
        t4.start();

        Thread t5 = new Thread("t5") {
            @Override
            public void run() {
                try {
                    t2.join();//WAITING,t2一致不会结束,无时限等待
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        };
        t5.start();

        Thread.sleep(1000);
        Thread t6 = new Thread("t4") {
            @Override
            public void run() {
                synchronized (TestThreadState.class) {
                    log.debug("t6 running");//t6线程和t4线程共用一个锁,t4先拿到锁,这是t6状态是BLOCKED
                }
            }
        };
        t6.start();


        log.debug("t1线程状态:{}",t1.getState());
        log.debug("t2线程状态:{}",t2.getState());
        log.debug("t3线程状态:{}",t3.getState());
        log.debug("t4线程状态:{}",t4.getState());
        log.debug("t5线程状态:{}",t5.getState());
        log.debug("t6线程状态:{}",t6.getState());
    }
}
上一篇 下一篇

猜你喜欢

热点阅读