0%

观测线程状态

观测线程状态

线程状态有的书籍叫线程生命周期。通过代码演示,观测线程状态:

创建线程myThread用到了lambda表达式,详细了解点击这里:传送门

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
//观察线程的状态
public class TestState {
public static void main(String[] args) throws InterruptedException {
Thread myThread = new Thread(()->{//创建线程myThread
for (int i = 0; i < 3; i++) {
try {
Thread.sleep(1000);//该方法,三秒钟打印三句话
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("myThread:hello world!");

}
System.out.println("myThread:--线程结束--");
});

//观察状态
Thread.State state = myThread.getState();
System.out.println(state);//线程刚刚创建,此时的状态是NEW

//观察启动后的状态
myThread.start();//启动线程
state = myThread.getState();
System.out.println(state);//查看线程状态,此时线程应该处于运行状态RUNNABLE(线程myThread中设置了线程休眠,不会那么快结束)

while (state != Thread.State.TERMINATED){//线程还没终止,则进入该循环。输出线程的状态
Thread.sleep(2000);
state = myThread.getState();
System.out.println(state);
}
}
}
  • 线程刚刚创建还没启动时,此时的状态是NEW
  • 线程正在运行,此时的状态是RUNNABLE
  • CPU调用了main线程中的System.out.println(state),故此时线程myThread的状态是TIMED_WAITING
  • 线程执行结束后,此时的状态是TERMINATED

运行结果:

1
2
3
4
5
6
7
8
9
10
NEW
RUNNABLE
myThread:hello world!
TIMED_WAITING
myThread:hello world!
myThread:hello world!
myThread:--线程结束--
TERMINATED

Process finished with exit code 0
若图片不能正常显示,请在浏览器中打开

欢迎关注我的其它发布渠道