首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

怎么获得java中的Exception的堆栈跟踪信息

2012-11-08 
如何获得java中的Exception的堆栈跟踪信息大家都知道,下面一段代码可以直接输出异常的堆栈跟踪信息:try{..

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

热点排行