臭名昭著的stop()停止線程的方法已不提倡使用了,原因是什么呢?
當(dāng)在一個(gè)線程對(duì)象上調(diào)用stop()方法時(shí),這個(gè)線程對(duì)象所運(yùn)行的線程就會(huì)立即停止,并拋出特殊的ThreadDeath()異常。這里的“立即”因?yàn)樘傲⒓础绷耍?
假如一個(gè)線程正在執(zhí)行:
synchronized void {
x = 3;
y = 4;
}
由于方法是同步的,多個(gè)線程訪問(wèn)時(shí)總能保證x,y被同時(shí)賦值,而如果一個(gè)線程正在執(zhí)行到x = 3;時(shí),被調(diào)用了 stop()方法,即使在同步塊中,它也干脆地stop了,這樣就產(chǎn)生了不完整的殘廢數(shù)據(jù)。而多線程編程中最最基礎(chǔ)的條件要保證數(shù)據(jù)的完整性,所以請(qǐng)忘記 線程的stop方法,以后我們?cè)僖膊灰f(shuō)“停止線程”了。
如何才能“結(jié)束”一個(gè)線程?
interupt()中斷線程
- 正常運(yùn)行.
- 處理結(jié)束前的工作,也就是準(zhǔn)備結(jié)束.
- 結(jié)束退出.
while(!isInterrupted()){
正常邏輯
}
,一個(gè)測(cè)試類,ThreadDemo
這樣ThreadDemo調(diào)用interrupt()方法,isInterrupted()為true,就會(huì)退出運(yùn)行。但是如果線程正在執(zhí)行wait,sleep,join方法,你調(diào)用interrupt()方法,這個(gè)邏輯就不完全了。
我們可以這樣處理:
public void run(){想一想,如果一個(gè)正在sleep的線程,在調(diào)用interrupt后,會(huì)如何?wait方法檢查到isInterrupted()為true,拋出異常, 而你又沒(méi)有處理。而一個(gè)拋出了InterruptedException的線程的狀態(tài)馬上就會(huì)被置為非中斷狀態(tài),如果catch語(yǔ)句沒(méi)有處理異常,則下一 次循環(huán)中isInterrupted()為false,線程會(huì)繼續(xù)執(zhí)行,可能你N次拋出異常,也無(wú)法讓線程停止。
while(!isInterrupted()){
try{
正常工作
}catch(InterruptedException e){
//nothing
}
}
}
}
這個(gè)錯(cuò)誤情況的實(shí)例代碼
ThreadA

































那么如何能確保線程真正停止?在線程同步的時(shí)候我們有一個(gè)叫“二次惰性檢測(cè)”(double check),能在提高效率的基礎(chǔ)上又確保線程真正中同步控制中。那么我把線程正確退出的方法稱為“雙重安全退出”,即不以isInterrupted ()為循環(huán)條件。而以一個(gè)標(biāo)記作為循環(huán)條件:
正確的ThreadA代碼是:



























更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
