Java print full StackTrace
我们在编写一些组件时,使用的日志系统有时并不能打印完整的堆栈信息,比如slf4j,log4j,我们在调用log.error("found error ...",e)
打印异常时,只打印一行异常信息。我们看下slf4j的源码
/**
* Log an exception (throwable) at the ERROR level with an
* accompanying message.
*
* @param msg the message accompanying the exception
* @param t the exception (throwable) to log
*/
public void error(String msg, Throwable t);
它在打印exception时,只是打印了堆栈当中的第一行Throwable
的信息, 而我们想要的是把整个堆栈都打印出来,这时我们会用下面方式打印堆栈信息。
e.printStackTrace()