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

你可能感兴趣的:(Java,log4j,.net,Blog,HTML)