Logger.error打印错误异常的详细堆栈信息
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Logger.error打印错误异常的详细堆栈信息
⼀、问题场景
使⽤Logger.error⽅法时只能打印出异常类型,⽆法打印出详细的堆栈信息,使得定位问题变得困难和不⽅便。
⼆、先放出结论
Logger类下有多个不同的error⽅法,根据传⼊参数的个数及类型的不同,⾃动选择不同的重载⽅法。
当error(Object obj)只传⼊⼀个参数时会将异常对象作为Object使⽤,并最终当做String打印出来,当使⽤两个参数error(String message, Throwable t),且第⼆个参数为Throwable时,才会将完整的异常堆栈打印出来。
三、代码⽰例
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
public class TestLogError {
public static final Logger LOGGER = LogManager.getLogger(TestLogError.class);
public static void main(String[] args) {
try{
// 模拟空指针异常
//Integer nullInt = Integer.valueOf(null);
int[] array = {1,2,3,4,5};
int outBoundInt = array[5];
}catch (Exception e){
// 直接打印,则只输出异常类型
LOGGER.error(e);
// 使⽤字符串拼接
LOGGER.error("使⽤ + 号连接直接输出 e : " + e);
LOGGER.error("使⽤ + 号连接直接输出 e.getMessage() : " + e.getMessage());
LOGGER.error("使⽤ + 号连接直接输出 e.toString() : " + e.toString());
// 使⽤逗号分隔,调⽤两个参数的error⽅法
LOGGER.error("使⽤ , 号使第⼆个参数作为Throwable : ", e);
// 尝试使⽤分隔符,第⼆个参数为Throwable,会发现分隔符没有起作⽤,第⼆个参数的不同据,调⽤不同的重载⽅法
LOGGER.error("第⼆个参数为Throwable,使⽤分隔符打印 {} : ", e);
// 尝试使⽤分隔符,第⼆个参数为Object,会发现分隔符起作⽤了,根据第⼆个参数的不同类型,调⽤不同的重载⽅法
LOGGER.error("第⼆个参数为Object,使⽤分隔符打印 {} ",123);
}
}
}
信息输出:
四、查看源码中的⽅法描述
根据⽅法重载特性,当只输⼊⼀个参数时,此对象会被当做Object进⾏打印输出,如果是Exception e的话,这⾥直接就toString()。
/**
* Logs a message object with the {@link Level#ERROR ERROR} level.
*
* @param message the message object to log.
*/
void error(Object message);
根据⽅法重载特性,当第⼆个参数为Throwable时,会打印出异常信息,并且包含异常堆栈信息。
/**
* Logs a message at the {@link Level#ERROR ERROR} level including the stack trace of the {@link Throwable}
* <code>t</code> passed as parameter.
*
* @param message the message object to log.
* @param t the exception to log, including its stack trace.
*/
void error(String message, Throwable t);
根据⽅法重载特性,当第⼆个参数为Object时,会根据占位符进⾏替换并打印出错误⽇志。
/**
* Logs a message with parameters at error level.
*
* @param message the message to log; the format depends on the message factory.
* @param p0 parameter to the message.
*/
void error(String message, Object p0);
五、结论
使⽤Logger.error(e)、Logger.error(e.getMessage())、Logger.error("some msg" + e)、Logger.error("some msg" +
e.getMessage()) 都是调⽤的error(Object message),这个⽅法都会将⼊参当作Object输出,不会打印堆栈信息。
在使⽤Logger.error("first param ",e)时会调⽤error(String message, Throwable t),此⽅法会完整的打印出错误堆栈信息。
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。