2、线程--线程之前的状态转换

线程状态转换的图解:

2、线程--线程之前的状态转换

1、新建状态(New):新创建了一个线程对象。


2、就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的start()方法。

  该状态的线程位于可运行线程池中,变得可运行,等待获取CPU的使用权。


3、运行状态(Running):就绪状态的线程获取了CPU,执行程序代码。

  处在“可执行状态”的线程对象一旦获得了 CPU 控制权,就会转换到“执行状态”
  在“执行状态”下,线程状态占用 CPU 时间片段,执行run 方法中的代码
  处在“执行状态”下的线程可以调用 yield 方法,
  该方法用于主动出让 CPU 控制权。线程对象出让控制权后回到“可执行状态”,重新等待调度。
  让出去cpu的使用权,还可以再次抢回来


4、阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。

  直到线程进入就绪状态,才有机会转到运行状态。

  阻塞的情况分三种:
  (一)、等待阻塞:运行的线程执行wait()方法,JVM会把该线程放入等待池中。(wait会释放持有的锁)
  (二)、同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池中。
  (三)、其他阻塞:运行的线程执行sleep()join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。

    当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。

    (注意,sleep是不会释放持有的锁)
5、死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

  处于“执行状态”的线程一旦从run方法返回(无论是正常退出还是抛出异常),就会进入“死亡状态”。
  已经“死亡”的线程不能重新运行,否则会抛出IllegalThreadStateException
  可以使用 Thread 类的 isAlive() 方法判断线程是否活着

测试:

public class isaliveTest  extends Thread{

    public void run() {
        for (int i = 0; i < 5; i++) {
            System.out.println(Thread.currentThread().getName() + "--" + i);
        }
    }
    
    public static void main(String[] args) {
        Thread t1 = new isaliveTest();
        //Thread t2 = new isaliveTest();
        System.out.println(t1.isAlive());//false
        t1.start();
        System.out.println(t1.isAlive());//true

        System.out.println(t1.isAlive());//false
    }
}

2、线程--线程之前的状态转换