问题:线程Thread执行了start方法就表示该线程已近执行了忙?
下面看线程生命周期图
由以上图可以知道,线程的生命周期大致可以分为以下五个阶段:
NEW
RUNNABLE
RUNNING
BLOCKED
TERMINATED
1.NEW状态
当我们new出一个Thread类的时候,此时它并不在执行状态,并且它并没有调用Start方法,那么此时线程的状态为New。
NEW状态通过Start 方法进入RUNNABLE 状态
2.RUNNABLE状态
一个线程new出来之后,通过调用start方法进入RUNNABLE 状态,此时线程正在会立即执行忙?答案是否定的,线程和进程一样 都要听命于CPU调度(其实是在等待获取CPU时间片),此时它只具备可执行资格,但是并没有真正的执行,
并且线程存在RUNNING 状态 不会一下就进入阻塞状态(BLOCKED)状态和消亡状态(TERMINATED),即使是在线程运行期间执行,wait,sleep或者其他阻塞该线程的操作,也必须获得CPU调度的执行权 才可以。RUNNABLE 的线程只能进入RUNNING状态或者意外终止。
3.RUNNING状态
一旦CPU轮询或者其他方式从任务可执行队列中选中了线程,才能真正的执行自己的代码,正在RUNNING 的线程其实也是RUNNABLE 的,则反过来不成立,在该状态中,线程可以发生如下的状态改变。
- 直接进入消亡状态(TERMINATED),比如执行了JDK已近不推荐的Stop方法。
- 进入阻塞状态(BLOCKED) ,如调用了Sleep()方法,或者wait方法。
- 进行了阻塞的IO操作,从而网络数据的读写进入了BLOCKED 状态 。
- 获取某个资源,从而加入到改锁的阻塞队列 ,从而进入了 BLOCKED状态。
- 由于CPU调度器轮询使该线程放弃执行,进入BLOCKED状态。
- 线程主动调用yield,放弃CPU执行权,进入BLOCKED状态。
4.BLOCKED状态
BLOCKED状态跟RUNNING状态类似,可以发生如下的状态改变
- 直接进入消亡状态(TERMINATED),比如执行了JDK已近不推荐的Stop方法。
- 线程阻塞的操作结束,比如读取到了想要读取的数据,进入RUNNABLED状态,
- 线程完成了休眠的状态,进入到了RUNNABLED状态
- Wait中的线程被其他线程唤醒(notify,notifyall),进入到RUNNABLED状态
- 线程获取到了某个锁资源,进入到了RUNNABLED状态
- 线程在阻塞过程中,被打断(调用Interrupt),从而进入到了RUNNABLED状态,
5.TERMINATED 状态
TERMINATED 是一个最终 的状态,该线程的状态不会有TERMINATED 转换到其他的状态,进入到TERMINATED 状态,意味着该线程的声明周期结束了,以下操作,会让线程进入TERMINATED 状态
- 线程正常结束,进入TERMINATED状态
- 线程运行出错,意外终止
- JVM Crash 所有线程都结束