java:获取异常的堆栈信息

做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));
        }
    }

我们看下打印结果:
java:获取异常的堆栈信息_第1张图片

你可能感兴趣的:(代码库)