我如何在Java中获得当前堆栈跟踪,就像在。net中,你可以做environment。stacktrace ?

我找到了Thread.dumpStack(),但这不是我想要的-我想要得到堆栈跟踪,而不是打印出来。


当前回答

我有一个实用工具方法,返回一个字符串与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));
}

其他回答

另一个解决方案(只有35 - 31个字符):

new Exception().printStackTrace();   
new Error().printStackTrace();

在android上,一个更简单的方法是使用这个:

import android.util.Log;
String stackTrace = Log.getStackTraceString(exception); 
for (StackTraceElement ste : Thread.currentThread().getStackTrace()) {
    System.out.println(ste + "\n");
}

你可以使用Thread.currentThread(). getstacktrace()。

它返回一个stacktraceelement数组,表示程序的当前堆栈跟踪。

用番石榴串:

Throwables.getStackTraceAsString(new Throwable())