为什么堆栈信息不打印到具体代码上?

最近追踪一个问题,发现前端没有异常信息,后端也没有异常信息。但是数据就是没有存入数据库。

后来调试发现,是异常信息打印不对。

后端以前的同事直接在事物类上,try{}catch(Expception e){map.put('err',e.getmessage())}了。而前端得到的map中只有err->null。其实这个时候大概可以推断出是空指针异常了。

但是由于没有打印堆栈信息,无法跟踪到是哪一行报空指针异常。因此回忆平时的异常日志都是有caused by。那这个为什么没有caused by?

解决办法1、在trycatch中输出e.printStackTrace();

2、在try catch中throw一个new Exception

如下代码

package com.feu.test;

/**
 * 测试异常
 */
public class MyException {
    public static void main(String[] args) throws AppException {
        MyException myException = new MyException();
        myException.entrance(myException);
    }
    private void entrance(MyException myException) throws AppException {
        try {
            myException.nullEx();
            myException.indexOutEx();
        }catch (Exception e){
            e.printStackTrace();
            throw new AppException(e);
        }
    }
    private void nullEx(){
        String ar=null;
        if(ar.equals(11)){

        }
    }
    private void indexOutEx(){
        String[] arr=new String[1];
        String a1 = arr[2];

    }

}

自定义异常类

package com.feu.test;

public class AppException  extends  Exception{
    public AppException(Exception e){
        super(e);
    }
}

当然也可以不用自定义异常类,直接用new Exception(e)

效果如下:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值