获取包含内部exception的完整字符串堆栈跟踪

Java的e.printStackTrace()不会打印内部exception堆栈跟踪的所有细节。

有没有一种现成的方法来以字符串forms生成完整的堆栈跟踪? (除了自己格式化)

编辑

我刚刚发现了printStackTrace()的作用 – 显然它过滤掉的堆栈帧正是内部exception和外部exception共有的堆栈帧。 所以实际上它是我想要的,而不是“完整”的堆栈跟踪。

我建议您使用Apache Commons lang中的ExceptionUtils类,它为此提供了有用的方法。

我最终滚动自己(我采取了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(); } } 

是的,您可以使用Throwable.getStackTrace()返回的StackTraceElement类并查找详细信息。

来自API:

数组的最后一个元素(假设数组的长度为非零)表示堆栈的底部,这是序列中的第一个方法调用。