現(xiàn)在,如果你要安全有效地終止一個線程,應(yīng)該采用以下這些方法:
1,線程正常執(zhí)行完畢,正常結(jié)束
也就是讓run方法執(zhí)行完畢,該線程就會正常結(jié)束。
2,監(jiān)視某些條件,結(jié)束線程的不間斷運行
然而,常常有些線程是伺服線程。它們需要長時間的運行,只有在外部某些條件滿足的情況下,才能關(guān)閉這些線程。
通常,它們執(zhí)行在一個while(true)的死循環(huán)中。
如:
@Override
publicvoid run() {
while(true){
someWork();
if(finished){
break;
}
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
/* TODO自動生成 catch 塊
*
*/
e.printStackTrace();
}
}
}
我們可以在while死循環(huán)內(nèi),每次循環(huán)時,察看外部條件,看看是否需要關(guān)閉當(dāng)前線程。如果是,就break,跳出死循環(huán),或者是拋出異常,跳出死循環(huán),結(jié)束線程。
3,捕獲InterruptedException 運行時異常,中斷當(dāng)前線程
有些執(zhí)行伺服任務(wù)的線程,在while(true)這樣的死循環(huán)內(nèi)部,是一個阻塞中的方法。此時,就不能采用第二種方法了。因為,當(dāng)該方法沒有返回時,該線程一直處于阻塞當(dāng)中,根本無法執(zhí)行其他語句。
此時,就需要調(diào)用該線程的interrupt方法,產(chǎn)生一個InterruptedException運行時異常,是阻塞中的那個方法拋出這個異常,從而讓我們有機會結(jié)束這個線程的執(zhí)行。
如:
@Override
publicvoid run() {
while(true){
try {
// getSendMessages 是BlockingQueue類。它的take方法將會阻塞!
responseMessage = this.getSendMessages().take();
} catch (InterruptedException e1) {
thrownew RuntimeException();
//或者break;
}
someWork();
}
一個外部的Thread 對象 指向這個線程。 需要結(jié)束這個線程時,只需要調(diào)用thread對象的interrupt() 方法,就會在
responseMessage = this.getSendMessages().take();
這條語句中產(chǎn)生一個InterruptedException異常,從而結(jié)束該線程的阻塞狀態(tài),通過拋出異常,或者break跳出死循環(huán),結(jié)束這個線程。