我如何在Java中获得当前堆栈跟踪,就像在。net中,你可以做environment。stacktrace ?
我找到了Thread.dumpStack(),但这不是我想要的-我想要得到堆栈跟踪,而不是打印出来。
我如何在Java中获得当前堆栈跟踪,就像在。net中,你可以做environment。stacktrace ?
我找到了Thread.dumpStack(),但这不是我想要的-我想要得到堆栈跟踪,而不是打印出来。
当前回答
在android上,一个更简单的方法是使用这个:
import android.util.Log;
String stackTrace = Log.getStackTraceString(exception);
其他回答
也许你可以试试这个:
catch(Exception e)
{
StringWriter writer = new StringWriter();
PrintWriter pw = new PrintWriter(writer);
e.printStackTrace(pw);
String errorDetail = writer.toString();
}
字符串'errorDetail'包含了堆栈跟踪。
对于那些只想获取当前堆栈跟踪到日志中的人来说,我建议:
getLogger().debug("Message", new Throwable());
干杯
在android上,一个更简单的方法是使用这个:
import android.util.Log;
String stackTrace = Log.getStackTraceString(exception);
StackTraceElement[] st = Thread.currentThread().getStackTrace();
如果你不关心堆栈的第一个元素是什么,那就没问题。
StackTraceElement[] st = new Throwable().getStackTrace();
将有一个定义的位置为您当前的方法,如果这很重要。
在Java 9中有一种新的方法:
public static void showTrace() {
List<StackFrame> frames =
StackWalker.getInstance( Option.RETAIN_CLASS_REFERENCE )
.walk( stream -> stream.collect( Collectors.toList() ) );
for ( StackFrame stackFrame : frames )
System.out.println( stackFrame );
}