例外のスタックトレースをstderr以外のストリームに出力するにはどうすればよいですか?私が見つけた1つの方法は、getStackTrace()を使用して、リスト全体をストリームに出力することです。
回答:
美しくはありませんが、それでも解決策は次のとおりです。
StringWriter writer = new StringWriter();
PrintWriter printWriter = new PrintWriter( writer );
exception.printStackTrace( printWriter );
printWriter.flush();
String stackTrace = writer.toString();
引数として印刷ストリームを受け取るThrowable.printStackTrace()の代替形式があります。http://download.oracle.com/javase/6/docs/api/java/lang/Throwable.html#printStackTrace(java.io.PrintStream)
例えば
catch(Exception e) {
e.printStackTrace(System.out);
}
これにより、スタックトレースがstdエラーではなくstdoutに出力されます。
Apache Commonsは、スタックトレースをスロー可能から文字列に変換するユーティリティを提供します。
使用法:
ExceptionUtils.getStackTrace(e)
完全なドキュメントについては、https://commons.apache.org/proper/commons-lang/javadocs/api-release/index.htmlを参照して ください。
stackTraceの取得に役立つメソッドを作成しました。
private static String getStackTrace(Exception ex) {
StringBuffer sb = new StringBuffer(500);
StackTraceElement[] st = ex.getStackTrace();
sb.append(ex.getClass().getName() + ": " + ex.getMessage() + "\n");
for (int i = 0; i < st.length; i++) {
sb.append("\t at " + st[i].toString() + "\n");
}
return sb.toString();
}
Throwableクラスには、という名前の2つの方法を提供しprintStackTrace
、受け入れ1PrintWriter
とにかかる1PrintStream
指定されたストリームにスタックトレースを出力し、。これらのいずれかを使用することを検討してください。
次のような詳細情報(パッケージの詳細)を含む、よりコンパクトなスタックトレースに関心がある場合。
java.net.SocketTimeoutException:Receive timed out
at j.n.PlainDatagramSocketImpl.receive0(Native Method)[na:1.8.0_151]
at j.n.AbstractPlainDatagramSocketImpl.receive(AbstractPlainDatagramSocketImpl.java:143)[^]
at j.n.DatagramSocket.receive(DatagramSocket.java:812)[^]
at o.s.n.SntpClient.requestTime(SntpClient.java:213)[classes/]
at o.s.n.SntpClient$1.call(^:145)[^]
at ^.call(^:134)[^]
at o.s.f.SyncRetryExecutor.call(SyncRetryExecutor.java:124)[^]
at o.s.f.RetryPolicy.call(RetryPolicy.java:105)[^]
at o.s.f.SyncRetryExecutor.call(SyncRetryExecutor.java:59)[^]
at o.s.n.SntpClient.requestTimeHA(SntpClient.java:134)[^]
at ^.requestTimeHA(^:122)[^]
at o.s.n.SntpClientTest.test2h(SntpClientTest.java:89)[test-classes/]
at s.r.NativeMethodAccessorImpl.invoke0(Native Method)[na:1.8.0_151]
spf4jライブラリからThrowables.writeToを使用してみることができます。
getStackTrace
配列を返すTrowable(Exception)のメソッドを呼び出すことができます(StackTraceElement
そのオブジェクトのtoStringメソッドを使用してトレースの1行を取得します)。