线程一1.0 线程的生命周期

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/insis_mo/article/details/88353899

关于Java中线程的生命周期,首先看一下下面这张较为经典的图:

上图中基本上囊括了Java中多线程各重要知识点。掌握了上图中的各知识点,Java中的多线程也就基本上掌握了。主要包括:

Java线程具有五中基本状态

(一),新建状态(New):当线程对象对创建后,即进入了新建状态,如:Thread t = new MyThread();

当我们用关键字 new  创建一个thread对象是,此时它并不处于执行状态,因为没有调用start方法启动该线程,那么线程的状态为new 状态,准确来说,它只是thread对象的状态,因为没有start,该线程根本不存在,与你用new创建一个普通的java对象没有什么区别;new通过start方法进入RUNNABLE状态

(二),就绪状态(Runnable):当调用线程对象的start()方法(t.start();),线程即进入就绪状态。处于就绪状态的线程,只是说明此线程已经做好了准备,随时等待CPU调度执行,并不是说执行了t.start()此线程立即就会执行;

此时才是真正的在jvm 进程中创建了一个线程,由于存在running状态,所以不会直接进入blocked状态和terminated状态,即使

是在线程的执行逻辑中调用wait,sleep或者其他的block的io操作等,也必须先获得cpu的调度执行权才可以,严格来说,runnable状态只能意外终止或者进入running 状态、

(三),运行状态(Running):当CPU开始调度处于就绪状态的线程时,此时线程才得以真正执行,即进入到运行状态。注:就     绪状态是进入到运行状态的唯一入口,也就是说,线程要想进入运行状态执行,首先必须处于就绪状态中;

一个正在running状态的线程事实上也是runnable的,但是反过来则不成立;

在该状态可以发生如下状态改变:

1,直接进入blocked状态,比如调用jdk已经不推荐使用的stop方法或者判断某个逻辑标识。

2,进入blocked状态比如调用了sleep或者wait方法而加入了waitset 中。

3进行某个阻塞的io操作,比如因网络数据的读写而进入了blocked状态,

4获取某个锁资源,从而加入到该锁的阻塞队列中而进入了blocked状态。

5由于cpu的调度器轮询使该线程放弃执行,进入runnable状态,

6 线程主动调用yield方法,放弃cpu执行权,进入runnable状态。

(四),阻塞状态(Blocked):处于运行状态中的线程由于某种原因,暂时放弃对CPU的使用权,停止执行,此时进入阻塞状态,直到其进入到就绪状态,才 有机会再次被CPU调用以进入到运行状态。根据阻塞产生的原因不同,阻塞状态又可以分为三种:

1.等待阻塞:运行状态中的线程执行wait()方法,使本线程进入到等待阻塞状态;

2.同步阻塞 -- 线程在获取synchronized同步锁失败(因为锁被其它线程所占用),它会进入同步阻塞状态;

3.其他阻塞 -- 通过调用线程的sleep()或join()或发出了I/O请求时,线程会进入到阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。

(五),死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

terminater 是线程的最终状态 ,该状态下不会切换到其他任何状态,下列情况进入tarminater 状态

1线程正常结束,结束生命周期

2线程运行出错意外结束

3jvm crash ,导致所有线程结束

猜你喜欢

转载自blog.csdn.net/insis_mo/article/details/88353899