Tian.Wang 发表于 2013-1-27 13:13:58

如何获得java中的Exception的堆栈跟踪信息

大家都知道,下面一段代码可以直接输出异常的堆栈跟踪信息:

try

{

...

}

catch(Exception e)

{

    e.printStackTrace();

}

可是,事实上在我们开发程序的过程中除非是做调试,一般均采用log4j做为错误信息输出的工具。而Exception本身并未提供将堆栈跟踪信息以字符串形式返回的函数。

/**
*
*/
package net.goldensharp;

import java.io.PrintWriter;
import java.io.StringWriter;

/**
* @author Wesley
*
*/
public class ExceptionUtil
{

/**
* 以字符串形式返回异常堆栈信息
* @param e
* @return 异常堆栈信息字符串
*/
public static String getStackTrace(Exception e)
{
StringWriter writer = new StringWriter();
e.printStackTrace(new PrintWriter(writer,true));

return writer.toString();
}

/**
* @param args
*/
public static void main(String[] args)
{
try
{
   throw new Exception("自定义异常");
}
catch(Exception ex)
{
   System.out.println(getStackTrace(ex));
}

}

}

文正摘自:http://iwesley.blog.hexun.com/9965836_d.html
页: [1]
查看完整版本: 如何获得java中的Exception的堆栈跟踪信息