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