新年快乐! 祝新的一年万事胜意! 魅力无限! 随心所欲! 蒸蒸日上!
文章目录
- 1. 线程的基本状态
- 2.Java中线程的状态
- 3. 线程的转换
1. 线程的基本状态
操作系统中线程有三个基本状态,就绪状态,运行状态,阻塞状态.
就绪状态, 已经获得除CPU之外的所有资源,只要得到CPU,可立即执行.
阻塞状态, 已经执行的进程因某种事件,无法继续执行.
运行状态, 程序已经在CPU上执行.
2.Java中线程的状态
Java中对线程进行了细化,参与调度的线程有6种可能的状态
- NEW,只创建了Thread对象,但还没调用start(),即没分配PCB.
- RUNNABLE,可运行的,指的是正在运行中的线程或者就绪队列中的线程.
- WAITING,执行==wait()或者join()==的线程,产生的阻塞,这个我们后面再说
- BLOCKED,调用已被别的对象加锁的代码,产生的阻塞.注意,以上三种状态都是阻塞状态.
- TIMED_WAITONG,==sleep()==中的线程.
- TERMINATED,进程结束,PCB被收回,但Thread对象还在.
3. 线程的转换
如下图的代码
执行结果如下图==,start之前==,只创建了Thread对象,还没分配PCB等资源,线程处于NEW状态.
调用start()后,线程开始被调度,处于RUNNABLE状态
线程执行完毕,回收PCB等资源,线程转为TERMINATED状态.
由于没加wait(),sleep(),和加锁操作,这个线程没有阻塞状态.
有sleep()的时候,可以显示线程sleep()时的状态.
public static void main(String[] args) throws InterruptedException {
Thread t = new Thread(() -> {
for (int i = 0; i < 1000; i++) {
// 这个循环体啥都不干, 也不 sleep
for (int j = 0; j < 100000; j++) {
int a = 0;
a += 10;
}
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
System.out.println("start之前" + t.getState());
t.start();
for(int i = 0; i < 1000; i++){
System.out.println("t 执行中的状态: " + t.getState());
}
t.join();
System.out.println("run之后" + t.getState());
}
如下图,进程处于sleep()时,线程处于阻塞TIMED_WAITING状态.