Java線(xiàn)程生命周期及轉(zhuǎn)換過(guò)程_第1頁(yè)
Java線(xiàn)程生命周期及轉(zhuǎn)換過(guò)程_第2頁(yè)
Java線(xiàn)程生命周期及轉(zhuǎn)換過(guò)程_第3頁(yè)
Java線(xiàn)程生命周期及轉(zhuǎn)換過(guò)程_第4頁(yè)
Java線(xiàn)程生命周期及轉(zhuǎn)換過(guò)程_第5頁(yè)
已閱讀5頁(yè),還剩6頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第Java線(xiàn)程生命周期及轉(zhuǎn)換過(guò)程目錄Java線(xiàn)程生命周期生命周期轉(zhuǎn)換1.從NEW到RUNNABLE2.從RUNNABLE到BLOCKED3.從RUNNABLE到WAITTING4.從RUNNABLE到TIMED_WATTING5.RUNNABLE到TERMINATED總結(jié)前言:

線(xiàn)程的生命周期指的是線(xiàn)程從創(chuàng)建到銷(xiāo)毀的整個(gè)過(guò)程,通常情況下線(xiàn)程的生命周期有以下5種:

初始狀態(tài)可運(yùn)行狀態(tài)運(yùn)行狀態(tài)休眠狀態(tài)終止?fàn)顟B(tài)

它們的狀態(tài)轉(zhuǎn)換如下圖所示:

Java線(xiàn)程生命周期

Java線(xiàn)程的生命周期和上面說(shuō)的生命周期是不同的,它有以下6種狀態(tài):

NEW(初始化狀態(tài))RUNNABLE(可運(yùn)行/運(yùn)行狀態(tài))BLOCKED(阻塞狀態(tài))WAITING(無(wú)時(shí)限等待狀態(tài))TIMED_WAITING(有時(shí)限等待狀態(tài))TERMINATED(終止?fàn)顟B(tài))

我們可以在Thread的源碼中可以找到這6種狀態(tài),如下所示:

當(dāng)然你也可以使用Java代碼,來(lái)打印所有的線(xiàn)程狀態(tài),如下代碼所示:

for(Thread.Statevalue:Thread.State.values()){

System.out.println(value);

}

以上程序的執(zhí)行結(jié)果如下圖所示:

生命周期轉(zhuǎn)換

接下來(lái)我們聊聊Java線(xiàn)程生命周期的轉(zhuǎn)換過(guò)程。

1.從NEW到RUNNABLE

當(dāng)我們創(chuàng)建一個(gè)線(xiàn)程的時(shí)候,也就是newThread的時(shí)候,此時(shí)線(xiàn)程是NEW狀態(tài),如下代碼所示:

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

//...

//獲取線(xiàn)程狀態(tài)

Thread.Statestate=thread.getState();

System.out.println(state);

以上程序的執(zhí)行結(jié)果如下圖所示:

然而調(diào)用了線(xiàn)程的start方法之后,線(xiàn)程的狀態(tài)就從NEW變成了RUNNABLE,

如下代碼所示:

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

//獲取到當(dāng)前執(zhí)行的線(xiàn)程

ThreadcurrThread=Thread.currentThread();

//獲取線(xiàn)程狀態(tài)

Thread.Statestate=currThread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println(state);

thread.start();

以上程序的執(zhí)行結(jié)果如下圖所示:

2.從RUNNABLE到BLOCKED

當(dāng)線(xiàn)程中的代碼排隊(duì)執(zhí)行synchronized時(shí),線(xiàn)程就會(huì)從RUNNABLE狀態(tài)變?yōu)锽LOCKED阻塞狀態(tài)

如下代碼所示:

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

try{

//等待100毫秒

Thread.sleep(100);

}catch(InterruptedExceptione){

e.printStackTrace();

System.out.println("排隊(duì)使用鎖");

synchronized(ThreadStates.class){

thread.start();

//讓主線(xiàn)程先得到鎖

synchronized(ThreadStates.class){

//獲取線(xiàn)程狀態(tài)

Thread.Statestate=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("首次獲取線(xiàn)程狀態(tài):"+state);

//休眠1s

try{

Thread.sleep(1000);

}catch(InterruptedExceptione){

e.printStackTrace();

//再次獲取線(xiàn)程狀態(tài)

state=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("第二次獲取線(xiàn)程狀態(tài):"+state);

}

以上程序的執(zhí)行結(jié)果如下圖所示:

當(dāng)線(xiàn)程獲取到synchronized鎖之后,就會(huì)從BLOCKED狀態(tài)轉(zhuǎn)變?yōu)镽UNNABLE狀態(tài)。

3.從RUNNABLE到WAITTING

線(xiàn)程調(diào)用wait()方法之后,就會(huì)從RUNNABLE狀態(tài)變?yōu)閃AITING無(wú)時(shí)限等待狀態(tài),如下所示:

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

synchronized(this){

try{

//線(xiàn)程休眠

this.wait();

}catch(InterruptedExceptione){

e.printStackTrace();

//啟動(dòng)線(xiàn)程

thread.start();

//獲取線(xiàn)程狀態(tài)

Thread.Statestate=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("首次獲取線(xiàn)程狀態(tài):"+state);

//休眠1s

try{

Thread.sleep(1000);

}catch(InterruptedExceptione){

e.printStackTrace();

//獲取線(xiàn)程狀態(tài)

state=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("第二次獲取線(xiàn)程狀態(tài):"+state);

以上程序的執(zhí)行結(jié)果如下圖所示:

當(dāng)調(diào)用了notify/notifyAll方法之后,線(xiàn)程會(huì)從WAITING狀態(tài)變成RUNNABLE狀態(tài),

如下代碼所示:

Objectlock=newObject();

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

synchronized(lock){

try{

//線(xiàn)程休眠

lock.wait();

//獲取當(dāng)前線(xiàn)程狀態(tài)

Thread.Statestate=Thread.currentThread().getState();

//打印線(xiàn)程狀態(tài)

System.out.println("獲取線(xiàn)程狀態(tài):"+state);

}catch(InterruptedExceptione){

e.printStackTrace();

//啟動(dòng)線(xiàn)程

thread.start();

//獲取線(xiàn)程狀態(tài)

Thread.Statestate=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("首次獲取線(xiàn)程狀態(tài):"+state);

//休眠1s

try{

Thread.sleep(100);

}catch(InterruptedExceptione){

e.printStackTrace();

//獲取線(xiàn)程狀態(tài)

state=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("第二次獲取線(xiàn)程狀態(tài):"+state);

//喚醒thread線(xiàn)程

synchronized(lock){

lock.notify();

}

以上程序的執(zhí)行結(jié)果如下圖所示:

4.從RUNNABLE到TIMED_WATTING

當(dāng)調(diào)用帶超時(shí)時(shí)間的等待方法時(shí),如sleep(xxx),線(xiàn)程會(huì)從RUNNABLE狀態(tài)變成TIMED_WAITING有時(shí)限狀態(tài),

如下代碼所示:

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

try{

Thread.sleep(1000);

}catch(InterruptedExceptione){

e.printStackTrace();

//啟動(dòng)線(xiàn)程

thread.start();

//獲取線(xiàn)程狀態(tài)

Thread.Statestate=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("首次獲取線(xiàn)程狀態(tài):"+state);

//休眠1s

try{

Thread.sleep(100);

}catch(InterruptedExceptione){

e.printStackTrace();

//獲取線(xiàn)程狀態(tài)

state=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("第二次獲取線(xiàn)程狀態(tài):"+state);

以上程序的執(zhí)行結(jié)果如下圖所示:

當(dāng)超過(guò)了超時(shí)時(shí)間之后,線(xiàn)程就會(huì)從TIMED_WAITING狀態(tài)變成RUNNABLE狀態(tài),

實(shí)現(xiàn)代碼如下:

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

try{

Thread.sleep(1000);

//獲取當(dāng)前線(xiàn)程狀態(tài)

Thread.Statestate=Thread.currentThread().getState();

//打印線(xiàn)程狀態(tài)

System.out.println("獲取線(xiàn)程狀態(tài):"+state);

}catch(InterruptedExceptione){

e.printStackTrace();

//啟動(dòng)線(xiàn)程

thread.start();

//獲取線(xiàn)程狀態(tài)

Thread.Statestate=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("首次獲取線(xiàn)程狀態(tài):"+state);

//休眠1s

try{

Thread.sleep(100);

}catch(InterruptedExceptione){

e.printStackTrace();

//獲取線(xiàn)程狀態(tài)

state=thread.getState();

//打印線(xiàn)程狀態(tài)

System.out.println("第二次獲取線(xiàn)程狀態(tài):"+state);

以上程序的執(zhí)行結(jié)果如下圖所示:

5.RUNNABLE到TERMINATED

線(xiàn)程執(zhí)行完之后,就會(huì)從RUNNABLE狀態(tài)變成TERMINATED銷(xiāo)毀狀態(tài),如下代碼所示:

//創(chuàng)建線(xiàn)程

Threadthread=newThread(newRunnable(){

@Override

publicvoidrun(){

//獲取當(dāng)前線(xiàn)程狀態(tài)

Thread.Statestate=Thread.currentThread().getState();

//打印線(xiàn)程狀態(tài)

System.out.println("獲取線(xiàn)程狀態(tài):"+state);

//啟動(dòng)線(xiàn)程

thread.start();

//等待100ms,待線(xiàn)程執(zhí)行完

Thread.sleep(1

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論