Java異常跟蹤棧定義與用法示例
本文實例講述了Java異常跟蹤棧定義與用法。分享給大家供大家參考,具體如下:
一、異常跟蹤棧簡介
異常對象的printStackTrace方法用于打印異常的跟蹤棧信息,根據(jù)printStackTrace方法的輸出結果,我們可以找到異常的源頭,并跟蹤到異常一路觸發(fā)的過程。
二、main方法中異常跟蹤棧的應用
1 代碼示例
class SelfException extends RuntimeException { SelfException(){} SelfException(String msg) { super(msg); } } public class PrintStackTraceTest { public static void main(String[] args) { firstMethod(); } public static void firstMethod() { secondMethod(); } public static void secondMethod() { thirdMethod(); } public static void thirdMethod() { throw new SelfException("自定義異常信息"); } }
2 運行結果
Exception in thread "main" SelfException: 自定義異常信息
at PrintStackTraceTest.thirdMethod(PrintStackTraceTest.java:26)
at PrintStackTraceTest.secondMethod(PrintStackTraceTest.java:22)
at PrintStackTraceTest.firstMethod(PrintStackTraceTest.java:18)
at PrintStackTraceTest.main(PrintStackTraceTest.java:14)
3 結果分析
只要異常沒有被完全捕獲,異常從發(fā)生異常的方法逐漸向外傳播,首先傳給該方法的調用者,該方法調用者再次創(chuàng)給其調用者……直至最后傳到 main方法,如果main方法依然沒有處理該異常,JVM會中止該程序,并打印異常的跟蹤棧信息。
三、多線程中異常跟蹤棧的應用
1 代碼示例
public class ThreadExceptionTest implements Runnable { public void run() { firstMethod(); } public void firstMethod() { secondMethod(); } public void secondMethod() { int a = 5; int b = 0; int c = a / b; } public static void main(String[] args) { new Thread(new ThreadExceptionTest()).start(); } }
2 運行結果
Exception in thread "Thread-0" java.lang.ArithmeticException: / by zero
at ThreadExceptionTest.secondMethod(ThreadExceptionTest.java:16)
at ThreadExceptionTest.firstMethod(ThreadExceptionTest.java:10)
at ThreadExceptionTest.run(ThreadExceptionTest.java:6)
at java.lang.Thread.run(Thread.java:619)
3 結果分析
程序在Thread的run方法中出現(xiàn)了ArithmeticException異常,這個異常的源頭是ThreadException的SecondMethod方法,位于文件16行。這個異常傳播到Thread類的run方法就會結束。
更多java相關內(nèi)容感興趣的讀者可查看本站專題:《Java面向對象程序設計入門與進階教程》、《Java數(shù)據(jù)結構與算法教程》、《Java操作DOM節(jié)點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設計有所幫助。
相關文章
Java基于JDBC連接數(shù)據(jù)庫及顯示數(shù)據(jù)操作示例
這篇文章主要介紹了Java基于JDBC連接數(shù)據(jù)庫及顯示數(shù)據(jù)操作,結合實例形式分析了Java使用jdbc進行mysql數(shù)據(jù)庫連接與數(shù)據(jù)讀取、顯示等相關操作技巧,需要的朋友可以參考下2018-06-06springboot定時任務@Scheduled執(zhí)行多次的問題
這篇文章主要介紹了springboot定時任務@Scheduled執(zhí)行多次問題的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10Java集合之Set、HashSet、LinkedHashSet和TreeSet深度解析
這篇文章主要介紹了Java集合之Set、HashSet、LinkedHashSet和TreeSet深度解析,List是有序集合的根接口,Set是無序集合的根接口,無序也就意味著元素不重復,更嚴格地說,Set集合不包含一對元素e1和e2 ,使得e1.equals(e2) ,并且最多一個空元素,需要的朋友可以參考下2023-09-09Java線程池ThreadPoolExecutor的使用及其原理詳細解讀
這篇文章主要介紹了Java線程池ThreadPoolExecutor的使用及其原理詳細解讀,線程池是一種多線程處理形式,處理過程中將任務添加到隊列,然后在創(chuàng)建線程后自動啟動這些任務,線程池線程都是后臺線程,需要的朋友可以參考下2023-12-12