Java thread.isInterrupted() 返回值不確定結(jié)果分析解決
一、代碼
先上代碼(以下這段代碼會有多種執(zhí)行結(jié)果)
@Test
public void test_interrupted_thread() throws Exception {
InterruptThread interruptThread = new InterruptThread();
interruptThread.start();
interruptThread.interrupt();
System.out.println("interruptThread.isInterrupted():" + interruptThread.isInterrupted());
}
public class InterruptThread extends Thread {
@Override
public void run() {
for (int i=0; i< 3; i++) {
System.out.println("i=" + (i + 1));
}
System.out.println("【InterruptThread】結(jié)束");
}
}
執(zhí)行結(jié)果1:
i=1
i=2
i=3
【Thread-0】【InterruptThread】結(jié)束
【main】interruptThread.isInterrupted():false
執(zhí)行結(jié)果2:
【main】interruptThread.isInterrupted():true
i=1
i=2
i=3
【Thread-0】【InterruptThread】結(jié)束
執(zhí)行結(jié)果3:
i=1
i=2
i=3
【Thread-0】【InterruptThread】結(jié)束
【main】interruptThread.isInterrupted():true
二、分析結(jié)果
執(zhí)行結(jié)果1:
Main線程調(diào)用了interruptThread.start();,interruptThread線程啟動,執(zhí)行了interruptThread線程內(nèi)容,同時Main線程調(diào)用了interruptThread.interrupt();,設(shè)定了interruptThread線程中斷標(biāo)記為true,最后InterruptThread結(jié)束,清除中斷標(biāo)記,Main線程調(diào)用interruptThread.isInterrupted() 獲取interruptThread線程中斷標(biāo)記為false。
執(zhí)行結(jié)果2:
Main線程調(diào)用了interruptThread.start();,interruptThread線程啟動,但是由于CPU隨機(jī)調(diào)度,在執(zhí)行了interruptThread線程內(nèi)容前,先執(zhí)行Main線程調(diào)用interruptThread.interrupt();,設(shè)定了interruptThread線程中斷標(biāo)記為true,且先調(diào)用interruptThread.isInterrupted()獲取interruptThread線程中斷標(biāo)記為true并輸出,最后在執(zhí)行interruptThread線程內(nèi)容。
執(zhí)行結(jié)果3:
Main線程調(diào)用了interruptThread.start();,interruptThread線程啟動,執(zhí)行了interruptThread線程內(nèi)容,同時Main線程調(diào)用了interruptThread.interrupt();,設(shè)定了interruptThread線程中斷標(biāo)記為true,最后InterruptThread結(jié)束,但是Main線程調(diào)用interruptThread.isInterrupted() 獲取interruptThread線程中斷標(biāo)記為true。(與執(zhí)行結(jié)果1執(zhí)行順序一致,但是最終結(jié)果不一致)
原因分析:
Main線程調(diào)用interruptThread.interrupt()后立即調(diào)用interruptThread.isInterrupted(),雖然interruptThread執(zhí)行結(jié)束,但有可能在interruptThread線程還未完成清除打斷標(biāo)記就Main線程就查看打斷標(biāo)記,此時仍然為true。
三、解決方案
如果Main線程要得到穩(wěn)定的false,即重置打斷標(biāo)記后的結(jié)果,有如下方案:
(1)需要Main線程在調(diào)用interruptThread.interrupt();,對Main線程sleep一會,給點(diǎn)時間,再通過調(diào)用interruptThread.isInterrupted()獲取interruptThread線程的中斷狀態(tài)。
@Test
public void test_interrupted_thread() throws Exception {
InterruptThread interruptThread = new InterruptThread();
interruptThread.start();
interruptThread.interrupt();
Thread.sleep(100);
System.out.println("【" + Thread.currentThread().getName() + "】" + "interruptThread.isInterrupted():" + interruptThread.isInterrupted());
}(2)也可以通過Main線程調(diào)用interruptThread.join(),讓Main線程等到interruptThread執(zhí)行直到中止后再調(diào)用interruptThread.isInterrupted()獲取interruptThread線程的中斷狀態(tài)。
@Test
public void test_interrupted_thread() throws Exception {
InterruptThread interruptThread = new InterruptThread();
interruptThread.start();
interruptThread.interrupt();
interruptThread.join();
System.out.println("【" + Thread.currentThread().getName() + "】" + "interruptThread.isInterrupted():" + interruptThread.isInterrupted());
}到此這篇關(guān)于Java thread.isInterrupted() 返回值不確定結(jié)果分析解決的文章就介紹到這了,更多相關(guān)Java thread.isInterrupted() 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring?Cloud?Gateway?2.x跨域時出現(xiàn)重復(fù)Origin的BUG問題
這篇文章主要介紹了Spring?Cloud?Gateway?2.x跨域時出現(xiàn)重復(fù)Origin的BUG問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
使用JSCH框架通過跳轉(zhuǎn)機(jī)訪問其他節(jié)點(diǎn)的方法
下面小編就為大家分享一篇使用JSCH框架通過跳轉(zhuǎn)機(jī)訪問其他節(jié)點(diǎn)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12
詳解Spring Cloud Zuul中路由配置細(xì)節(jié)
本篇文章主要介紹了詳解Spring Cloud Zuul中路由配置細(xì)節(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
深入探究TimSort對歸并排序算法的優(yōu)化及Java實(shí)現(xiàn)
這篇文章主要介紹了TimSort歸并排序的優(yōu)化及Java實(shí)現(xiàn),TimSort 是一個歸并排序做了大量優(yōu)化的版本,需要的朋友可以參考下2016-05-05
關(guān)于Idea中的.properties文件顯示問題
這篇文章主要介紹了關(guān)于Idea中的.properties文件顯示問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07

