用排队买票的情景去理解JAVA线程间的状态转换
-
新建(new):新创建了一个线程对象。 (大家好,我是新来的,老爸是个程序猿,今天要给全家买火车票过几天趁着国庆开开心心去旅游----新生状态)
-
可运行(runnable):线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。该状态的线程位于可运行线程池中,等待被线程调度选中,获取cpu 的使用权 。 (我时刻准备着买票----准备状态)
-
运行(running):可运行状态(runnable)的线程获得了cpu 时间片(timeslice) ,执行程序代码。 (买票时跟出票mm交流顺便泡妞,需折腾一段时间【CPU 理解为出票mm的交流时间(Chu Piao Unit】----买票状态)
-
阻塞(block):阻塞状态是指线程因为某种原因放弃了cpu 使用权,也即让出了cpu timeslice,暂时停止运行。直到线程进入可运行(runnable)状态,才有机会再次获得cpu timeslice 转到运行(running)状态。---- 人塞人状态 阻塞的情况分三种: (一). 等待阻塞:运行(running)的线程执行o.wait()方法,JVM会把该线程放入等待队列(waitting queue)中。 (进到售票大厅惊呆了!人超多,好拥挤啊!大厅里面非常有秩序,一进去,就被彪悍的保安大哥塞在售票大厅的其中一个队伍中排队!排队前,程序猿老爸不让我拿着所有的身份证先----排队状态) Java Thread State 线程状态为“waiting for monitor entry”
(二). 同步阻塞:运行(running)的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池(lock pool)中。 (好不容易轮到自己,才发现原来是每三排队伍才对应一个出票mm,谁争到谁先买票,赶紧去抢!---争抢状态) Java Thread State 线程状态为“in Object.wait()”:
(三). 其他阻塞:运行(running)的线程执行Thread.sleep(long ms)或t.join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。 当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入可运行(runnable)状态。 (跟售票mm交流买票眼神耗太多了,犯困了,干脆睡个短觉或者化身雷锋让急着赶回家看病的老人先买张票上车!先让让吧,反正我是这个队伍的第一位,身份证可都在我手上握紧不放--- 礼让状态) Java Thread State 线程状态为“waiting on condition”
- 死亡(dead):线程run()、main() 方法执行结束,或者因异常退出了run()方法,则该线程结束生命周期。死亡的线程不可再次复生。 (买到全部票了!终于可以回家了!---- 解放状态)
“碧池”大家都听说过吧! 回头一望那售票大厅,正在排队那一帮人叫“猥池(等待池waiting pool)”,正在争抢出票mm那一帮人叫“琐池”(锁池lock pool) !
现在,闭上你的眼睛,想象买票场景的各种感受,可帮助您记住线程状态变化的各种流程! 若有误导请留言指正! 若有更多情景,请留言提醒!
参考《一张图让你看懂JAVA线程间的状态转换》 http://my.oschina.net/mingdongcheng/blog/139263 《Java多线程:线程状态》 http://blog.csdn.net/huang_xw/article/details/7316354 《在 TDA 工具里看到 Java Thread State 的第一反应是》 http://itindex.net/detail/43158-tda-%E5%B7%A5%E5%85%B7-java