学而不思则罔 思而不学则殆.|

漆原Blog

园龄:5年10个月粉丝:0关注:1

Java获取异常堆栈信息

在日常开发时,经常会遇到代码抛异常后,需要把异常信息保存到数据库或者上传到云服务器做cache分析。这时候就需要获取异常的堆栈信息(详细错误信息)。

有的人用e.getMessage()来获取异常信息,但是这样获取到的信息内容并不全,而且有时候为空。我们可以用下面方法来获取。

public static String getStackTrace(Throwable throwable){
    StringWriter sw = new StringWriter();
    PrintWriter pw = new PrintWriter(sw);
    try {
        throwable.printStackTrace(pw);
        return sw.toString();
    } finally {
        pw.close();
    }
}

使用也很简单:

public static void test() {
    try {
        int i = 0;
        int m = 10 / i;
    } catch (Exception e) {
        System.out.println(e.getMessage());
        System.out.println("------调皮的分割线------");
        System.out.println(ExceptionUtil.getStackTrace(e));
    }
}

我们看下打印结果:

转载于:https://blog.csdn.net/q649381130/article/details/77182346

本文作者:漆原Blog

本文链接:https://www.cnblogs.com/7moon/p/13818679.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   漆原Blog  阅读(2511)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起