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

