java线程中的五种状态,java线程五种状态

  java线程中的五种状态,java线程五种状态

  00-1010 1.线程2的5种状态。Java线程3的6种状态。Java线程状态转换综述

  00-1010从操作系统层面来说,任何线程一般都有五种状态,即创建、就绪、运行、阻塞和终止。

  (1) 新建状态(NEW)

  当一个新的线程被一个构造函数(比如new Thread())在程序中创建时,这个线程就处于创建状态。此时,它已经拥有了相应的内存空间和其他资源,但还没有开始执行。

  (2) 就绪状态(READ)

  创建新的线程对象后,可以通过调用线程的start()方法来启动线程。当线程启动时,线程进入可运行状态。由于CPU还没有分配,线程会进入线程队列等待CPU服务,这说明它已经具备了运行条件。当系统挑选一个线程对象执行时,它将从等待状态进入执行状态。系统选择的动作称为“CPU调度”。一旦获得CPU,线程就进入运行状态,自动调用自己的run方法。

  (3) 运行状态(RUNNING)

  当处于就绪状态的线程被调用并获得处理器资源时,该线程进入运行状态。此时,线程对象的run()方法被自动调用。

  (4) 阻塞状态( BLOCKED)

  在一些特殊情况下,比如被人为挂起或者需要进行耗时的输入输出操作,一个正在执行的线程会放弃自己的CPU,暂时挂起自己的执行,从而进入阻塞状态。

  在可执行状态下,如果调用sleep()、suspend()、wait()等方法,线程都会进入阻塞状态。当线程被阻塞时,它不能进入队列。只有当阻塞的原因消除后,线程才会进入就绪状态,并再次在就绪队列中等待。此时被CPU调度选中后,会从原来的停止位置继续执行。

  记住:拥塞解除后,会回到就绪状态,而不是运行状态。

  (5) 死亡状态(TERMINATED)

  线程调用stop()、destory()或run()后,线程处于死状态。处于死状态的线程无法继续运行。

  00-1010 Java中线程的生命周期分为6个状态。Thread类有一个实例属性和一个实例方法,专门用于保存和获取线程的状态。其中,用于保存线程实例状态的实例属性为:

  //将线程的状态保存为整数。Private volatile int线程状态=0;//返回当前线程的状态,枚举类型值public state getstate(){ returnsun . misc . VM . tothreadstate(thread status);}线程。State是一个内部枚举类,定义了六个枚举常量,分别代表Java线程的六种状态,如下:

  公共枚举状态{//新状态new,//运行状态RUNNABLE,/** *阻塞状态* Object.wait */BLOCKED,/* * *等待状态* object . wait * thread . join * lock support . park */waiting,/* * *限时等待状态* thread . sleep * object . wait * thread . join * lock support . park until * lock support . park nanos */timed _ waiting,//终止状态终止;}常见的状态有四种,分别是:新建、可运行、终止、TIMED_WAITING。

  (1) NEW状态

  Java对新状态的描述是:成功创建但未调用start()方法启动的线程实例都处于新状态。

  当然,并不是一旦调用了Thread线程实例的start()方法,它的状态就从新状态变成了可运行状态。此时并不是说线程立即获取CPU时间片并立即执行,这需要操作系统的一系列内部操作。

  (2) RUNNABLE状态

  调用线程实例的start()方法后,如果线程获得了CPU时间片,下一步就开始了。

  执行,JVM将异步调用线程的run()方法执行其业务代码。那么在run()方法被异步调用之前,JVM做了哪些事情呢?当Java线程的Thread实例的start()方法被调用后,操作系统中的对应线程进入的并不是运行状态,而是就绪状态,而Java线程并没有这个就绪状态。操作系统中线程的就绪状态是什么状态的呢?JVM的线程状态与其幕后的操作系统线程状态之间的转换关系简化后如图:

  

 

  一个操作系统线程如果处于就绪状态,就表示万事俱备,只欠东风,即该线程已经满足执行条件,但是还不能执行。处于就绪状态的线程需要等待系统的调度,一旦就绪状态被系统选中,获得CPU时间片,线程就开始占用CPU,开始执行线程的代码,这时线程的操作系统状态发生了改变,进入了运行状态。

  在操作系统中,处于运行状态的线程在CPU时间片用完之后,又回到就绪状态,等待CPU的下一次调度。就这样,操作系统线程在就绪状态和执行状态之间被系统反复地调度,这种情况会一直持续,直到线程的代码逻辑执行完成或者异常终止。这时线程的操作系统状态又发生了改变,进入线程的最后状态——TERMINATED状态。

  就绪状态和运行状态都是操作系统中的线程状态。在Java语言中,并没有细分这两种状态,而是将这两种状态合并成同一种状态——RUNNABLE状态。因此,在Thread.State枚举类中,没有定义线程的就绪状态和运行状态,只是定义了RUNNABLE状态。这就是Java线程状态和操作系统中线程状态不同的地方。

  总之,NEW状态的Thread实例调用了start()方法后,线程的状态将变成RUNNABLE状态。尽管如此,线程的run()方法不一定会马上被并发执行,需要在线程获取了CPU时间片之后才真正启动并发执行。

  (3) TERMINATED状态

  处于RUNNABLE状态的线程在run()方法执行完成之后就变成终止状态TERMINATED了。当然,如果在run()方法执行过程中发生了运行时异常而没有被捕获,run()方法将被异常终止,线程也会变成TERMINATED状态。

  (4) TIMED_WAITING状态

  线程处于一种特殊的等待状态,准确地说,线程处于限时等待状态。能让线程处于限时等待状态的操作大致有以下几种:

  Thread.sleep(int n):使得当前线程进入限时等待状态,等待时间为n毫秒。Object.wait():带时限的抢占对象的monitor锁。Thread.join():带时限的线程合并。LockSupport.parkNanos():让线程等待,时间以纳秒为单位。LockSupport.parkUntil():让线程等待,时间可以灵活设置。

 

  

3. Java线程状态的转换

 

  

 

  

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注盛行IT的更多内容!

 

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: