Javaのe.printStackTrace()は、内部例外のスタックトレースのすべての詳細を出力するわけではありません。
文字列形式で完全なスタックトレースを生成する準備ができている方法はありますか?(自分でフォーマットする以外に)
編集
printStackTrace()が何をするのかを知りました。明らかに、フィルターで除外されるスタックフレームは、内側の例外と外側の例外に共通するものです。したがって、実際には、それはむしろ私が望むものであり、「完全な」スタックトレースではありません。
Javaのe.printStackTrace()は、内部例外のスタックトレースのすべての詳細を出力するわけではありません。
文字列形式で完全なスタックトレースを生成する準備ができている方法はありますか?(自分でフォーマットする以外に)
編集
printStackTrace()が何をするのかを知りました。明らかに、フィルターで除外されるスタックフレームは、内側の例外と外側の例外に共通するものです。したがって、実際には、それはむしろ私が望むものであり、「完全な」スタックトレースではありません。
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から:
配列の最後の要素(配列の長さがゼロ以外であると想定)は、スタックの最下部を表します。これは、シーケンスの最初のメソッド呼び出しです。