线程状态

线程状态

  • 创建状态

new

Thread t = new Thread()

线程对象一旦创建就进入到新生状态

  • 就绪状态

当调用start()方法,现场立即进入就绪状态,但不意味着立即调度执行

  • 运行状态

进入运行状态,线程才真正执行线程体的代码块

  • 阻塞状态

当调用sleep,wait或同步锁定时,线程进入阻塞状态,就是代码不往下执行,阻塞事件解除后,重新进入就绪状态,等待CPU调度执行

  • 死亡状态

线程中断或者结束,一旦进入死亡状态,就不能再次启动

public class TestState {

    public static void main(String[] args) {
        Thread thread = new Thread(()->{
            for (int i = 0; i < 10; i++) {
                try {
                    Thread.sleep(200);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            System.out.println("线程运行");
        });

        //观察线程状态
        Thread.State state = thread.getState();
        System.out.println(state);//NEW

        //启动后线程状态
        thread.start();
        state = thread.getState();
        System.out.println(state);//RUN

        while (state != Thread.State.TERMINATED) {
            //只要线程不终止,就一直输出线程状态
            state = thread.getState();
            System.out.println(state);
        }
    }
}

停止线程

  1. 不推荐使用JDK提供的stop()、destroy()方法
  2. 推荐线程自己停止下来
  3. 建议使用一个标志位来终止变量,当flag=false,则终止线程运行
//测试stop
//1.建议线程正常停止---》利用次数,不建议死循环
//2.建议使用标志位---》设置一个标志位
//3.不要使用stop或者destroy等过失或者JDK不建议使用的方法
public class TestStop implements Runnable{

    //1.设置一个标志位
    private boolean flag = true;
    @Override
    public void run() {
        int i = 0;
        while (flag){
            System.out.println("run...thread" + i++);
        }
    }

    //设置一个公开的方法停止线程,转换标志位
    public void stop(){
        this.flag = false;
    }

    public static void main(String[] args) {
        TestStop testStop = new TestStop();
        new Thread(testStop).start();
        for (int i = 0; i < 1000; i++) {
            System.out.println("main" + i);
            if (i == 900) {
                //调用停止
                testStop.stop();
                System.out.println("线程停止了");
            }
        }
    }
}
posted @ 2022-03-26 09:14  NeverGGp  阅读(44)  评论(0)    收藏  举报