線程的幾種狀態(tài)
- 新建( new ):新創(chuàng)建了一個線程對象.
- 可運行( runnable ):線程對象創(chuàng)建后,其他線程(比如 main 線程)調(diào)用了該對象 的 start ()方法。該狀態(tài)的線程位于可運行線程池中,等待被線程調(diào)度選中,獲 取 cpu 的使用權 .
- 運行( running ):可運行狀態(tài)( runnable )的線程獲得了 cpu 時間片( timeslice ) ,執(zhí)行程序代碼。
- 阻塞( block ):阻塞狀態(tài)是指線程因為某種原因放棄了 cpu 使用權,也即讓出了 cpu timeslice ,暫時停止運行。直到線程進入可運行( 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)。當 sleep ()狀態(tài)超時、 join ()等待線程終止或者超時、或者 I / O 處理完畢時,線程重新轉(zhuǎn)入可運行( runnable )狀態(tài)。
- 死亡( dead ):線程 run ()、 main () 方法執(zhí)行結(jié)束,或者因異常退出了 run ()方法,則該線程結(jié)束生命周期。死亡的線程不可再次復生。

wait、notify、sleep、join、yield對鎖的影響
這幾個方法中除了wait方法會釋放鎖,其他方法都不會釋放鎖。

浙公網(wǎng)安備 33010602011771號