如何获得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]