新年快乐! 祝新的一年万事胜意! 魅力无限! 随心所欲! 蒸蒸日上!
文章目录
- 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状态.
 



















