Java線程組與未處理異常實(shí)例分析
本文實(shí)例講述了Java線程組與未處理異常。分享給大家供大家參考,具體如下:
一 點(diǎn)睛
從JDK1.5開始,Java加強(qiáng)了線程的異常處理,如果線程執(zhí)行過程中拋出了一個未處理的異常,JVM在結(jié)束該線程之前會自動查找是否有對應(yīng)的Thread.UncaughtExceptionHandler對象,如果找到該處理器對象,將會調(diào)用該對象的uncaughtException(Thread t, Throwable e)方法來處理該異常。
Thread.UncaughtExceptionHandler是Thread類的一個內(nèi)部公共靜態(tài)接口,該接口內(nèi)只有一個方法:void uncaughtException(Thread t, Throwable e),該方法中的t代表出現(xiàn)異常的線程,而e代表該線程拋出的異常。
線程組處理異常的默認(rèn)流程:
1 如果該線程組有父線程組,則調(diào)用父線程組的uncaughtException方法來處理該異常。
2 如果該線程實(shí)例所屬的線程類有默認(rèn)的異常處理器(由setDefaultUncaughtExceptionHandler方法設(shè)置的異常處理器),那就調(diào)用該異常處理器來處理該異常。
3 如果該異常對象是ThreadDeath的對象,將不做任何處理;否則將異常跟蹤棧的信息打印到System.err錯誤輸出流,并結(jié)束該線程。
二 實(shí)戰(zhàn)
1 代碼
// 定義自己的異常處理器 class MyExHandler implements Thread.UncaughtExceptionHandler { // 實(shí)現(xiàn)uncaughtException方法,該方法將處理線程的未處理異常 public void uncaughtException(Thread t, Throwable e) { System.out.println(t + " 線程出現(xiàn)了異常:" + e); } } public class ExHandler { public static void main(String[] args) { // 設(shè)置主線程的異常處理器 Thread.currentThread().setUncaughtExceptionHandler (new MyExHandler()); int a = 5 / 0; // ① System.out.println("程序正常結(jié)束!"); } }
2 運(yùn)行
Thread[main,5,main] 線程出現(xiàn)了異常:java.lang.ArithmeticException: / by zero
3 說明
程序指定的異常處理器對未捕獲的異常進(jìn)行了處理,但程序依然不會正常結(jié)束。這說明異常處理器與通過catch捕獲異常是不同的——當(dāng)使用catch捕獲異常時,異常不會向上傳遞給上一級調(diào)用者,但使用異常處理器對異常進(jìn)行處理之后,異常依然會傳遞給上一級調(diào)用者。
更多java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java進(jìn)程與線程操作技巧總結(jié)》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計(jì)有所幫助。
相關(guān)文章
Java反射機(jī)制如何解決數(shù)據(jù)傳值為空的問題
這篇文章主要介紹了Java反射機(jī)制如何解決數(shù)據(jù)傳值為空的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03idea2020安裝MybatisCodeHelper插件的圖文教程
這篇文章主要介紹了idea2020安裝MybatisCodeHelper插件的方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09