12

Javaのe.printStackTrace()は、内部例外のスタックトレースのすべての詳細を出力するわけではありません。

文字列形式で完全なスタックトレースを生成する準備ができている方法はありますか?(自分でフォーマットする以外に)

編集

printStackTrace()が何をするのかを知りました。明らかに、フィルターで除外されるスタックフレームは、内側の例外と外側の例外に共通するものです。したがって、実際には、それはむしろ私が望むものであり、「完全な」スタックトレースではありません。

4

3 に答える 3

9

Apache Commons langのExceptionUtilsクラスを使用することをお勧めします。これは、そのための便利なメソッドを提供します。

于 2009-08-18T09:36:43.200 に答える
8

私は自分自身を転がすことになりました(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-18T11:26:53.400 に答える
2

はい、Throwable.getStackTrace()によって返されるStackTraceElementクラスを使用して、詳細を見つけることができます。

APIから:

配列の最後の要素(配列の長さがゼロ以外であると想定)は、スタックの最下部を表します。これは、シーケンスの最初のメソッド呼び出しです。

于 2009-08-18T09:37:02.653 に答える