Java的e.printStackTrace()没有打印内部异常堆栈跟踪的所有细节。
是否有现成的方法以字符串形式生成完整的堆栈跟踪?(除了自己格式化外)
编辑
我刚刚发现了printStackTrace()做了什么-显然它过滤掉的堆栈帧正是内部异常和外部异常所共有的。事实上,这正是我想要的,而不是“完全”堆栈跟踪。
发布于 2009-08-18 03:26:53
最后我滚动了自己的(我使用了Throwable.printStackTrace()的实现并对其进行了一些调整):
public static String joinStackTrace(Throwable e) {
StringWriter writer = null;
try {
writer = new StringWriter();
joinStackTrace(e, writer);
return writer.toString();
}
finally {
if (writer != null)
try {
writer.close();
} catch (IOException e1) {
// ignore
}
}
}
public static void joinStackTrace(Throwable e, StringWriter writer) {
PrintWriter printer = null;
try {
printer = new PrintWriter(writer);
while (e != null) {
printer.println(e);
StackTraceElement[] trace = e.getStackTrace();
for (int i = 0; i < trace.length; i++)
printer.println("\tat " + trace[i]);
e = e.getCause();
if (e != null)
printer.println("Caused by:\r\n");
}
}
finally {
if (printer != null)
printer.close();
}
}
发布于 2009-08-18 01:36:43
我建议您使用Apache中的ExceptionUtils类,该类为此提供了有用的方法。
发布于 2009-08-18 01:37:02
是的,您可以使用由StackTraceElement ()返回的Throwable.getStackTrace类并查找详细信息。
来自API:
数组的最后一个元素(假设数组的长度为非零)表示堆栈的底部,这是序列中的第一个方法调用。
https://stackoverflow.com/questions/1292858
复制相似问题