我如何在Java中获得当前堆栈跟踪,就像在。net中,你可以做environment。stacktrace ?
我找到了Thread.dumpStack(),但这不是我想要的-我想要得到堆栈跟踪,而不是打印出来。
我如何在Java中获得当前堆栈跟踪,就像在。net中,你可以做environment。stacktrace ?
我找到了Thread.dumpStack(),但这不是我想要的-我想要得到堆栈跟踪,而不是打印出来。
当前回答
托尼,作为对公认答案的评论,给出了似乎是最好的答案,实际上回答了OP的问题:
Arrays.toString(Thread.currentThread().getStackTrace()).replace( ',', '\n' );
... OP没有询问如何从异常的堆栈跟踪中获取字符串。尽管我是Apache Commons的忠实粉丝,但当有像上面这么简单的东西时,使用外部库是没有逻辑理由的。
其他回答
你可以使用Thread.currentThread(). getstacktrace()。
它返回一个stacktraceelement数组,表示程序的当前堆栈跟踪。
对于那些只想获取当前堆栈跟踪到日志中的人来说,我建议:
getLogger().debug("Message", new Throwable());
干杯
另一个解决方案(只有35 - 31个字符):
new Exception().printStackTrace();
new Error().printStackTrace();
StackTraceElement[] stackTraceElements = Thread.currentThread().getStackTrace();
数组的最后一个元素表示堆栈的底部,这是序列中最近的方法调用。
A StackTraceElement has getClassName(), getFileName(), getLineNumber() and getMethodName().
循环遍历StackTraceElement并获得所需的结果。
for (StackTraceElement ste : stackTraceElements )
{
//do your stuff here...
}
用番石榴串:
Throwables.getStackTraceAsString(new Throwable())