六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 59|回复: 0

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

[复制链接]

升级  86%

9

主题

9

主题

9

主题

童生

Rank: 1

积分
43
 楼主| 发表于 2013-1-27 13:13:58 | 显示全部楼层 |阅读模式
大家都知道,下面一段代码可以直接输出异常的堆栈跟踪信息:

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
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表