Java線程組與未處理異常實(shí)例分析
本文實(shí)例講述了Java線程組與未處理異常。分享給大家供大家參考,具體如下:
一 點(diǎn)睛
從JDK1.5開始,Java加強(qiáng)了線程的異常處理,如果線程執(zhí)行過(guò)程中拋出了一個(gè)未處理的異常,JVM在結(jié)束該線程之前會(huì)自動(dòng)查找是否有對(duì)應(yīng)的Thread.UncaughtExceptionHandler對(duì)象,如果找到該處理器對(duì)象,將會(huì)調(diào)用該對(duì)象的uncaughtException(Thread t, Throwable e)方法來(lái)處理該異常。
Thread.UncaughtExceptionHandler是Thread類的一個(gè)內(nèi)部公共靜態(tài)接口,該接口內(nèi)只有一個(gè)方法:void uncaughtException(Thread t, Throwable e),該方法中的t代表出現(xiàn)異常的線程,而e代表該線程拋出的異常。
線程組處理異常的默認(rèn)流程:
1 如果該線程組有父線程組,則調(diào)用父線程組的uncaughtException方法來(lái)處理該異常。
2 如果該線程實(shí)例所屬的線程類有默認(rèn)的異常處理器(由setDefaultUncaughtExceptionHandler方法設(shè)置的異常處理器),那就調(diào)用該異常處理器來(lái)處理該異常。
3 如果該異常對(duì)象是ThreadDeath的對(duì)象,將不做任何處理;否則將異常跟蹤棧的信息打印到System.err錯(cuò)誤輸出流,并結(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 說(shuō)明
程序指定的異常處理器對(duì)未捕獲的異常進(jìn)行了處理,但程序依然不會(huì)正常結(jié)束。這說(shuō)明異常處理器與通過(guò)catch捕獲異常是不同的——當(dāng)使用catch捕獲異常時(shí),異常不會(huì)向上傳遞給上一級(jí)調(diào)用者,但使用異常處理器對(duì)異常進(jìn)行處理之后,異常依然會(huì)傳遞給上一級(jí)調(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緩存操作技巧匯總》
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。
相關(guān)文章
JAVA內(nèi)存模型和Happens-Before規(guī)則知識(shí)點(diǎn)講解
在本篇文章里小編給大家整理的是一篇關(guān)于JAVA內(nèi)存模型和Happens-Before規(guī)則知識(shí)點(diǎn)內(nèi)容,有需要的朋友們跟著學(xué)習(xí)下。2020-11-11
Java中Array List與Linked List的實(shí)現(xiàn)分析
這篇文章主要給大家介紹了關(guān)于Array List與Linked List實(shí)現(xiàn)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
spring boot整合netty的實(shí)現(xiàn)方法
這篇文章主要介紹了spring boot整合netty的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
SpringBoot集成Druid監(jiān)控慢SQL的詳細(xì)過(guò)程
數(shù)據(jù)庫(kù)連接池是一個(gè)至關(guān)重要的組成部分,一個(gè)優(yōu)秀的數(shù)據(jù)庫(kù)連接池可以顯著提高應(yīng)用程序的性能和可伸縮性,常見的連接池:Druid、HikariCP、C3P0、DBCP等等,本文將詳細(xì)介紹如何在Spring Boot項(xiàng)目中配置數(shù)據(jù)源,集成Druid連接池,以實(shí)現(xiàn)更高效的數(shù)據(jù)庫(kù)連接管理2024-06-06
MyBatis如何調(diào)用存儲(chǔ)過(guò)程與存儲(chǔ)函數(shù)
這篇文章主要介紹了MyBatis如何調(diào)用存儲(chǔ)過(guò)程與存儲(chǔ)函數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11

