詳解Java線程中斷知識點
下面的這斷代碼大家應該再熟悉不過了,線程休眠需要捕獲或者拋出線程中斷異常,也就是你在睡覺的時候突然有個人沖進來把你吵醒了。
try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); }
此時線程被打斷后,代碼會繼續(xù)運行或者拋出異常結(jié)束運行,這并不是我們需要的中斷線程的作用。
到底是什么是線程中斷?
線程中斷即線程運行過程中被其他線程給打斷了,它與 stop 最大的區(qū)別是:stop 是由系統(tǒng)強制終止線程,而線程中斷則是給目標線程發(fā)送一個中斷信號,如果目標線程沒有接收線程中斷的信號并結(jié)束線程,線程則不會終止,具體是否退出或者執(zhí)行其他邏輯由目標線程決定。
我們來看下線程中斷最重要的 3 個方法,它們都是來自 Thread 類!
1、java.lang.Thread#interrupt
中斷目標線程,給目標線程發(fā)一個中斷信號,線程被打上中斷標記。
2、java.lang.Thread#isInterrupted()
判斷目標線程是否被中斷,不會清除中斷標記。
3、java.lang.Thread#interrupted
判斷目標線程是否被中斷,會清除中斷標記。
線程中斷實戰(zhàn)
我們來實例演示下線程中斷如何用!
示例1(中斷失?。?/p>
/** * 微信公眾號:Java技術棧 */ private static void test1() { Thread thread = new Thread(() -> { while (true) { Thread.yield(); } }); thread.start(); thread.interrupt(); }
請問示例1中的線程會被中斷嗎?答案:不會,因為雖然給線程發(fā)出了中斷信號,但程序中并沒有響應中斷信號的邏輯,所以程序不會有任何反應。
示例2:(中斷成功)
/** * 微信公眾號:Java技術棧 */ private static void test2() { Thread thread = new Thread(() -> { while (true) { Thread.yield(); // 響應中斷 if (Thread.currentThread().isInterrupted()) { System.out.println("Java技術棧線程被中斷,程序退出。"); return; } } }); thread.start(); thread.interrupt(); }
我們給示例2加上了響應中斷的邏輯,程序接收到中斷信號打印出信息后返回退出。
示例3(中斷失敗)
/** * 微信公眾號:Java技術棧 */ private static void test3() throws InterruptedException { Thread thread = new Thread(() -> { while (true) { // 響應中斷 if (Thread.currentThread().isInterrupted()) { System.out.println("Java技術棧線程被中斷,程序退出。"); return; } try { Thread.sleep(3000); } catch (InterruptedException e) { System.out.println("Java技術棧線程休眠被中斷,程序退出。"); } } }); thread.start(); Thread.sleep(2000); thread.interrupt(); }
示例3 sleep() 方法被中斷,并輸出了 Java技術棧線程休眠被中斷,程序退出。 程序繼續(xù)運行……為什么呢?
來看 sleep 的源碼:
可以看出 sleep() 方法被中斷后會清除中斷標記,所以循環(huán)會繼續(xù)運行。。
示例4(中斷成功)
/** * 微信公眾號:Java技術棧 */ private static void test4() throws InterruptedException { Thread thread = new Thread(() -> { while (true) { // 響應中斷 if (Thread.currentThread().isInterrupted()) { System.out.println("Java技術棧線程被中斷,程序退出。"); return; } try { Thread.sleep(3000); } catch (InterruptedException e) { System.out.println("Java技術棧線程休眠被中斷,程序退出。"); Thread.currentThread().interrupt(); } } }); thread.start(); Thread.sleep(2000); thread.interrupt(); }
示例4全部信息輸出并正常退出,只是在 sleep() 方法被中斷并清除標記后手動重新中斷當前線程,然后程序接收中斷信號返回退出。
通過以上 4 個中斷示例,相信對 Java 線程中斷的概念有了全面的了解。
相關文章
使用Java自定義注解實現(xiàn)一個簡單的令牌桶限流器
限流是在分布式系統(tǒng)中常用的一種策略,它可以有效地控制系統(tǒng)的訪問流量,保證系統(tǒng)的穩(wěn)定性和可靠性,在本文中,我將介紹如何使用Java自定義注解來實現(xiàn)一個簡單的令牌桶限流器,需要的朋友可以參考下2023-10-10Java?file.delete刪除文件失敗,Windows磁盤出現(xiàn)無法訪問的文件問題
這篇文章主要介紹了Java?file.delete刪除文件失敗,Windows磁盤出現(xiàn)無法訪問的文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06maven中no main manifest attribute的問題解決
本文主要介紹了maven中no main manifest attribute的問題解決,這個錯誤通常意味著Spring Boot應用在啟動時遇到了問題,下面就來具體介紹一下,感興趣的可以了解一下2024-08-08Java請求轉(zhuǎn)發(fā)和請求重定向區(qū)別詳解
這篇文章主要介紹了Java請求轉(zhuǎn)發(fā)和請求重定向區(qū)別詳解,請求轉(zhuǎn)發(fā)和請求重定向,但二者是完全不同的,所以我們今天就來盤他們的區(qū)別介紹,需要的朋友可以參考一下2022-07-07feign post參數(shù)對象不加@RequestBody的使用說明
這篇文章主要介紹了feign post參數(shù)對象不加@RequestBody的使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10