Thread.stop, Thread.suspend, Thread.resume和Runtime.runFinalizersOnExit這些終止線程運行的方法已經(jīng)被廢棄,使用它們是極端不安全的!現(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)閉當前線程。如果是,就break,跳出死循環(huán),或者是拋出異常,跳出死循環(huán),結(jié)束線程。
3,捕獲InterruptedException運行時異常,中斷當前線程。
有些執(zhí)行伺服任務(wù)的線程,在while(true)這樣的死循環(huán)內(nèi)部,是一個阻塞中的方法。此時,就不能采用第二種方法了。因為,當該方法沒有返回時,該線程一直處于阻塞當中,根本無法執(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é)束這個線程。以上就是為大家介紹的全部JAVA中斷線程的方,僅供參考。
成為優(yōu)秀的程序員有沒有捷徑?怎樣學習才能成為優(yōu)秀的java程序員呢?完事開頭難,想學好一件事不容易,必須要堅持下去。
以上內(nèi)容是關(guān)于JAVA中斷線程的方法的介紹,要想了解更多相關(guān)信息、教育培訓內(nèi)容,請隨時關(guān)注唯學網(wǎng),小編會第一時間為大家更新、跟進最新信息。