zoukankan      html  css  js  c++  java
  • 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
        }
    }

  • 相关阅读:
    update(十)
    perl-basic-数据类型&引用
    R-barplot()
    leetcode-22-string
    Java-basic-7-面向对象
    Java-basic-6-方法
    Java-basic-4-数据类型
    Java-basic-3-运算符-修饰符-循环
    Java-basic-2-
    leetcode-21-knapsack
  • 原文地址:https://www.cnblogs.com/Mrchengs/p/10803007.html
Copyright © 2011-2022 走看看