• 135456

    文章

  • 827

    评论

  • 13

    友链

  • 最近新加了换肤功能,大家多来逛逛吧~~~~
  • 喜欢这个网站的朋友可以加一下QQ群,我们一起交流技术。

Java异常堆栈信息转String

2年想跳槽阿里,大咖揭秘大厂面试的那些事儿 >>

平时使用e.getMessage()或e.printStackTrace();

第一种报异常时要throw new RuntimeException("异常"),只能得到异常2字.

第二种e.printStackTrace();只是打印,不返回任何数据.

而服务器一般是集群或其他方式部署,查看日志的话太麻烦,可以吧堆栈信息转成String等类型,然后进行保存到数据库、放在页面隐藏域中方便查看.

介绍3种方法供选择:

方法一:

package name.xu;public class CallStack {    public static void printCallStatck() {
        Throwable ex = new Throwable();
        StackTraceElement[] stackElements = ex.getStackTrace();        
        if (stackElements != null) {            
            for (int i = 0; i < stackElements.length; i++) {
                System.out.print(stackElements[i].getClassName()+"/t");
                System.out.print(stackElements[i].getFileName()+"/t");
                System.out.print(stackElements[i].getLineNumber()+"/t");
                System.out.println(stackElements[i].getMethodName());
                System.out.println("-----------------------------------");
            }
        }
    }
    
}

 

方法二:

Exception e = new Exception("this is a log");
e.printStackTrace();

 

方法三:

String fullStackTrace = org.apache.commons.lang.exception.ExceptionUtils.getFullStackTrace(e)

 

方法四:

Thread.currentThread().getStackTrace()


 转载至链接:https://my.oschina.net/zjllovecode/blog/1927568


695856371Web网页设计师②群 | 喜欢本站的朋友可以收藏本站,或者加入我们大家一起来交流技术!

0条评论

Loading...


发表评论

电子邮件地址不会被公开。 必填项已用*标注

自定义皮肤 主体内容背景
打开支付宝扫码付款购买视频教程
遇到问题联系客服QQ:419400980
注册梁钟霖个人博客