java异常捕获(7) 异常跟踪栈

本文通过两个示例详细解析了Java中异常栈跟踪的工作原理,包括如何通过异常栈信息定位问题源头,适用于初学者理解异常处理机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 当发生异常的时候,JVM会在控制台打印出异常的跟踪栈,可以通过这个跟踪栈得到一路除法的过程,以下为代码示例
    package TrackingStack;
    
    import java.io.Serializable;
    
    class SelfException extends RuntimeException {
        SelfException() {}
        SelfException(String msg){super(msg);}
    }
    public class PtintStackTrace {
        public static void main(String args[]){
            first();
        }
    
        public static void first(){
            second();
        }
    
        public static void second(){
            third();
        }
    
        public static void third(){
            throw new SelfException("Exception~");
        }
    }
    

    运行这个程序,可以看到控制台打印出一连串的异常信息,这些信息记录了异常的发生,如下

    Exception in thread "main" TrackingStack.SelfException: Exception~
    	at TrackingStack.PtintStackTrace.third(PtintStackTrace.java:23)
    	at TrackingStack.PtintStackTrace.second(PtintStackTrace.java:19)
    	at TrackingStack.PtintStackTrace.first(PtintStackTrace.java:15)
    	at TrackingStack.PtintStackTrace.main(PtintStackTrace.java:11)

     

  2. 下面是另外一个例子,异曲同工

    package TrackingStack;
    
    public class ThreadException 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 ThreadException()).start();
        }
    }
    

    控制台输出的信息:

    Exception in thread "Thread-0" java.lang.ArithmeticException: / by zero
    	at TrackingStack.ThreadException.secondMethod(ThreadException.java:13)
    	at TrackingStack.ThreadException.firstMethod(ThreadException.java:8)
    	at TrackingStack.ThreadException.run(ThreadException.java:5)
    	at java.lang.Thread.run(Thread.java:748)

    异常捕获就到这里

  3. 这是我看李刚编著的《疯狂Java讲义》后总结出来的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值