NEW: 安排了工作, 还未开始行动
RUNNABLE: 可工作的. 又可以分成正在工作中和即将开始工作.
BLOCKED: 这几个都表示排队等着其他事情
WAITING: 这几个都表示排队等着其他事情
TIMED_WAITING: 这几个都表示排队等着其他事情
TERMINATED: 工作完成了
当继承Thread类和实现了Runnable接口,就可以创建线程,新建一个对象就是初始状态
可运行状态(runnable)的线程获得了cpu 时间片(timeslice) ,执行程序代码,就到了运行状态
阻塞状态是指线程因为某种原因放弃了cpu 使用权,也即让出了cpu 时间片,暂时停止运行。直到线程进入可运行(runnable)状态,才有机会再次获得cpu 时间片转到运行(running)状态
NEW , RUNNABLE ,TERMINATED 状态的转移
使用 isAlive 方法判定线程的存活状态
public class ThreadStateTransfer { public static void main(String[] args) throws InterruptedException { Thread t = new Thread(() -> { for (int i = 0; i < 1000_0000; i++) { } }, "李四"); System.out.println(t.getName() + ": " + t.getState());; t.start(); while (t.isAlive()) { System.out.println(t.getName() + ": " + t.getState());; } System.out.println(t.getName() + ": " + t.getState());; } }
yield() 方法,让出 CPU执行权
/** * yield让出CPU执行权 */ public class ThreadYield { public static void main(String[] args) { Thread thread = new Thread(() ->{ Thread t1 = Thread.currentThread(); for (int i = 0; i < 10; i++) { //让出CPU执行权 Thread.yield(); System.out.println("执行了线程" + t1.getName()); } },"张三"); thread.start(); //创建并启动线程 new Thread(() -> { Thread t1 = Thread.currentThread(); for (int i = 0; i < 10; i++) { System.out.println("执行了线程" + t1.getName()); } },"李四").start(); }
结论
yield 不改变线程的状态, 但是会重新去排队