美文网首页并发编程
并发编程(三):线程状态

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

作者: codeMover | 来源:发表于2020-04-03 23:52 被阅读0次

    线程状态

    • 现在线程的状态有五种和六种,五种是以操作系统层面描述的,六种是以Java Thread State枚举描述的

    线程五种状态

    image.png
    1. 【初始状态】仅在语言层面创建了线程,还未与操作系统线程关联
    2. 【可运行状态(就绪状态)】该线程已经被创建(与操作系统线程关联),可以由CPU调度执行
    3. 【运行状态】获取了CPU时间片,线程RUN方法代码在执行
    • 当CPU时间片用完,会从【运行状态】转至【可运行状态】,会导致线程上下文切换
    1. 【阻塞状态】
    • 如果调用阻塞API,如BIO读写文件,这时线程实际不会用到CPU,会导致上下文切换,线程进入【阻塞状态】
    • 等BIO操作完毕,会由操作系统唤醒阻塞的线程,转换至【可运行状态】
    1. 【终止状态】表示线程已经执行完毕,生命周期已经结束,不会再装换为其他状态

    线程六种状态

    • 在Thread类中的enum Stste内部枚举类


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

    相关文章

      网友评论

        本文标题:并发编程(三):线程状态

        本文链接:https://www.haomeiwen.com/subject/qezlphtx.html