在java中找到被吃的异常

1. 背景介绍

在开发过程中, 遇到平台代码不规范的写法(如下图), 将异常直接吃掉, 或者吞掉了详细堆栈. 当生产运行到这段代码时, 抛出的信息非常少, 而且不知道是哪行代码抛出的异常, 排除问题非常困难. 为解决这个问题, 想到了一个好办法.

在这里插入图片描述

2. 解决思路

  1. 将jdk中的java.lang.Exception类重写. 在本机创建Exception这个类, 并在构造器中将堆栈输出
package java.lang;

public class Exception extends Throwable {
    static final long serialVersionUID = -3387516993124229948L;

    public Exception() {
        super();
        this.printStackTrace(); // 将堆栈输出
    }

    public Exception(String message) {
        super(message);
        this.printStackTrace();
    }

    public Exception(String message, Throwable cause) {
        super(message, cause);
        this.printStackTrace();
    }

    public Exception(Throwable cause) {
        super(cause);
        this.printStackTrace();
    }

    protected Exception(String message, Throwable cause,
                        boolean enableSuppression,
                        boolean writableStackTrace) {
        super(message, cause, enableSuppression, writableStackTrace);
        this.printStackTrace();
    }
}
  1. 通过javac命令将Exception.java构建, 得到Exception.class
  2. 再将Exception.class替换到$JAVA_HOME/jre/lib/rt.jar中的对应Execetion类

2. 验证

  1. 测试类
public class TestUserDefineNullPointerException {

    static void f1() {
        f2();
    }

    private static void f2() {
        String s = null;
        s.length();
    }

    public static void main(String[] args) {
        System.out.println("start...");

        try {
            f1();
        } catch (Exception e) {
        // 此处Exception虽然被吃了, 但控制台依然打出了异常堆栈
            System.out.println("in..........");
        }
    }
}
  1. 控制台输出结果
in..........
	at chapter4.TestUserDefineNullPointerException.f2(TestUserDefineNullPointerException.java:11)
	at chapter4.TestUserDefineNullPointerException.f1(TestUserDefineNullPointerException.java:6)
	at chapter4.TestUserDefineNullPointerException.main(TestUserDefineNullPointerException.java:18)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值