首先我们想要知道什么是线程的状态:简而言之就是目前线程所处的一种情况,因为我们要管理线程,所以要先知道线程处在什么情况下。类似于进程。
public class AllThreadState {
public static void main(String[] args) {
Thread.State[] values =Thread.State.values();//枚举所有的线程状态
for (Thread.State s: values) {//打印
System.out.println(s);
}
}
}
打印结果:
查看官方文档可以知道,并且 我们可以大致的把它人为的分为4个阶段
1.(创建)NEW 尚未启动的线程处于此状态。
2.(就绪/运行)RUNNABLE 在Java虚拟机中执行的线程处于此状态。关于RUNNABLE 状态,我们人为的把它再分为 READY就绪/RUNNING运行。实际上这两个状态并不存在。为了方便介绍引入的。
3.(阻塞)BLOCKED 被阻塞等待监视器锁定的线程处于此状态。
WAITING 正在等待另一个线程执行特定动作的线程处于此状态。
TIMED_WAITING 正在等待另一个线程执行动作达到指定等待时间的线程处于此状态。
4.(终结)TERMINATED 已退出的线程处于此状态。
这里我们参考进程的通用状态,实际上这个状态图可以作为所有具有调度状态的参考。
线程的状态转移图 或称为 有限状态机
值得我们记住的两点是:
1.线程必须占有cpu才能运行代码。
2.无论什么情况,一个线程没有cpu它始终需要先进入READY状态,等待排队分配cpu才能进入RUNNING状态。
以一个代码来展示线程运行时的状态。
import java.util.Scanner;
import java.util.concurrent.TimeUnit;
public class ThreadStateTransfer {
static class SubThread extends Thread {
@Override
public void run() {
Scanner scanner = new Scanner(System.in);
scanner.nextLine();//利用等待输入让线程结束
System.out.println("子线程即将退出");
/*
try {
TimeUnit.SECONDS.sleep(5);//利用休眠5秒钟让线程结束
} catch (InterruptedException e) {
e.printStackTrace();
}
}*/
}
public static void main(String[] args) throws InterruptedException {
Thread p = new SubThread();
System.out.println(p.getState());
p.start();
System.out.println(p.getState());
while (p.isAlive()) {
System.out.println(p.getState());
TimeUnit.SECONDS.sleep(1);
}
System.out.println(p.getState());
}
}
}
等待输入运行过程, “是的” 为任意输入
休眠结束运行过程
ps:Thread.yield() 表示放弃了抢占cpu,但是并不表示放弃了抢占cpu的资格。