线程状态概述
当线程被创建并启动以后,它既不是一启动就进入了执行状态,也不是一直处于执行状态。
在线程的生命周期中, 有几种状态呢?
在API中 java.lang.Thread.State
枚举中给出了六种线程状态。
这里先列出各个线程状态发生的条件,下面将会对每种状态进行详细解析
线程状态 | 详细说明 |
---|---|
NEW(新建) | 线程刚被创建,但是并未启动。还没调用start方法。 |
Runnable(可运行) | 正在Java虚拟机中执行的线程处于这种状态。 |
Blocked(阻塞) | 阻塞并等待监视器锁(锁对象)的线程处于这种状态。 |
Waiting(无限等待) | 无限期等待另一个线程执行一个特别动作(唤醒)的线程处于这一状态。 |
Timed Waiting(计时等待) | 等待另一个线程来执行取决于指定等待时间的操作的线程处于这种状态。 |
Teminated(被终止) | 已退出的线程处于这种状态。 |
线程状态如何相互转换
代码演示
import lombok.SneakyThrows;
/**
* @author layman
*/
public class Demo01 {
public static void main(String[] args) throws InterruptedException {
ThreadA t1 = new ThreadA();
ThreadA t2 = new ThreadA();
System.out.println("t1的线程状态:" + t1.getState());
t1.start();
System.out.println("t1的线程状态:" + t1.getState());
//确保t1线程进入睡眠
Thread.sleep(500L);
System.out.println("t1的线程状态:" + t1.getState());
t2.start();
//t2的线程状态:RUNNABLE? 为什么不是BLOCKED?奇怪?
System.out.println("t2的线程状态:" + t2.getState());
//确保t1线程执行完毕
Thread.sleep(5000L);
System.out.println("t1的线程状态:" + t1.getState());
ThreadB t3 = new ThreadB();
t3.start();
Thread.sleep(100L);
System.out.println("t3的线程状态:" + t3.getState());
}
}
class ThreadA extends Thread{
@SneakyThrows
@Override
public void run() {
Thread.sleep(3000L);
}
}
class ThreadB extends Thread{
private Object lock = new Object();
@SneakyThrows
@Override
public void run() {
synchronized (lock){
lock.wait();
}
}
}
运行结果: