淺談線程的幾種可用狀態(tài)
更新時間:2017年09月01日 09:19:29 投稿:jingxian
下面小編就為大家?guī)硪黄獪\談線程的幾種可用狀態(tài)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
1. 新建( new ):新創(chuàng)建了一個線程對象。
2. 可運行( runnable ):線程對象創(chuàng)建后,其他線程(比如 main 線程)調(diào)用了該對象 的 start ()方法。該狀態(tài)的線程位于可運行線程池中,等待被線程調(diào)度選中,獲 取 cpu 的使用權(quán) 。
3. 運行( running ):可運行狀態(tài)( runnable )的線程獲得了 cpu 時間片( timeslice ) ,執(zhí)行程序代碼。
4. 阻塞( block ):阻塞狀態(tài)是指線程因為某種原因放棄了 cpu 使用權(quán),也即讓出了 cpu timeslice ,暫時停止運行。直到線程進(jìn)入可運行( runnable )狀態(tài),才有 機會再次獲得 cpu timeslice 轉(zhuǎn)到運行( running )狀態(tài)。阻塞的情況分三種:
(一). 等待阻塞:運行( running )的線程執(zhí)行 o . wait ()方法, JVM 會把該線程放 入等待隊列( waitting queue )中。
(二). 同步阻塞:運行( running )的線程在獲取對象的同步鎖時,若該同步鎖 被別的線程占用,則 JVM 會把該線程放入鎖池( lock pool )中。
(三). 其他阻塞:運行( running )的線程執(zhí)行 Thread . sleep ( long ms )或 t . join ()方法,或者發(fā)出了 I / O 請求時, JVM 會把該線程置為阻塞狀態(tài)。 當(dāng) sleep ()狀態(tài)超時、 join ()等待線程終止或者超時、或者 I / O 處理完畢時,線程重新轉(zhuǎn)入可運行( runnable )狀態(tài)。
5. 死亡( dead ):線程 run ()、 main () 方法執(zhí)行結(jié)束,或者因異常退出了 run ()方法,則該線程結(jié)束生命周期。死亡的線程不可再次復(fù)生。

以上這篇淺談線程的幾種可用狀態(tài)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java servlet、filter、listener、interceptor之間的區(qū)別和聯(lián)系
這篇文章主要介紹了Java servlet、filter、listener、interceptor之間的區(qū)別和聯(lián)系的相關(guān)資料,需要的朋友可以參考下2016-11-11