我如何在Java中获得当前堆栈跟踪,就像在。net中,你可以做environment。stacktrace ?
我找到了Thread.dumpStack(),但这不是我想要的-我想要得到堆栈跟踪,而不是打印出来。
我如何在Java中获得当前堆栈跟踪,就像在。net中,你可以做environment。stacktrace ?
我找到了Thread.dumpStack(),但这不是我想要的-我想要得到堆栈跟踪,而不是打印出来。
当前回答
也许你可以试试这个:
catch(Exception e)
{
StringWriter writer = new StringWriter();
PrintWriter pw = new PrintWriter(writer);
e.printStackTrace(pw);
String errorDetail = writer.toString();
}
字符串'errorDetail'包含了堆栈跟踪。
其他回答
这是一个老帖子,但这是我的解决方案:
Thread.currentThread().dumpStack();
更多信息和更多的方法: http://javarevisited.blogspot.fr/2013/04/how-to-get-current-stack-trace-in-java-thread.html
我有一个实用工具方法,返回一个字符串与stacktrace:
static String getStackTrace(Throwable t) {
StringWriter sw = new StringWriter();
PrintWriter pw = new PrintWriter(sw, true);
t.printStackTrace(pw);
pw.flush();
sw.flush();
return sw.toString();
}
然后就像这样…
...
catch (FileNotFoundException e) {
logger.config(getStackTrace(e));
}
try {
}
catch(Exception e) {
StackTraceElement[] traceElements = e.getStackTrace();
//...
}
or
Thread.currentThread().getStackTrace()
StackTraceElement[] stackTraceElements = Thread.currentThread().getStackTrace();
数组的最后一个元素表示堆栈的底部,这是序列中最近的方法调用。
A StackTraceElement has getClassName(), getFileName(), getLineNumber() and getMethodName().
循环遍历StackTraceElement并获得所需的结果。
for (StackTraceElement ste : stackTraceElements )
{
//do your stuff here...
}
另一个解决方案(只有35 - 31个字符):
new Exception().printStackTrace();
new Error().printStackTrace();