如何用Logger.error打印错误异常的详细堆栈信息

2024-02-22 16:18

本文主要是介绍如何用Logger.error打印错误异常的详细堆栈信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片

推荐用法

LOGGER.error("xxxx error:{}|", e.getMessage(), e);LOGGER.error("xxxx error:",  e);

使用说明

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{int[] array={1,2,3,4};System.out.println(array[5]);}catch (Exception e){/*** LOGGER.error("错误信息:"+e)* 输出:* 错误信息:java.lang.ArrayIndexOutOfBoundsException: 5*/LOGGER.error("错误信息:"+e);/*** LOGGER.error("错误信息:",e)* 输出:*  错误信息:*  java.lang.ArrayIndexOutOfBoundsException: 5*  at com.syf.com.learn.TestLogError.main(TestLogError.java:14) [classes/:?]*/LOGGER.error("错误信息:",e);/***  LOGGER.error("错误信息:{}",e);*  只有一个参数时,占位符被吞掉*  输出:*  错误信息:{}*  java.lang.ArrayIndexOutOfBoundsException: 5*  at com.syf.com.learn.TestLogError.main(TestLogError.java:14) [classes/:?]*/LOGGER.error("错误信息:{}",e);/*** LOGGER.error("错误信息:{}",e,e);* 输出* 错误信息:java.lang.ArrayIndexOutOfBoundsException: 5* java.lang.ArrayIndexOutOfBoundsException: 5* at com.syf.com.learn.TestLogError.main(TestLogError.java:14) [classes/:?]*/LOGGER.error("错误信息:{}",e,e);/**推荐用法:* LOGGER.error("错误信息:{}",e.getMessage(),e);* 输出:* 错误信息:5* java.lang.ArrayIndexOutOfBoundsException: 5* at com.syf.com.learn.TestLogError.main(TestLogError.java:14) [classes/:?]*/LOGGER.error("错误信息:{}",e.getMessage(),e);}}
}

查看源码中的方法描述

根据方法重载特性,当只输入一个参数时,此对象会被当做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.* @param p1 parameter to the message.*/void error(String message, Object p0, Object p1);

结论

使用LOGGER.error("xxx:"+e);是调用的error(Object message),这个方法都会将入参当作Object输出,不会打印堆栈信息。

在使用

LOGGER.error(":{}",e.getMessage(),e);

LOGGER.error("findError:",e);​​​​​​​

时会调用error(String message, Throwable t),此方法会完整的打印出错误堆栈信息。

以上就是本文的全部内容,希望对大家的学习有所帮助。

这篇关于如何用Logger.error打印错误异常的详细堆栈信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/735796

相关文章

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Python中ModuleNotFoundError: No module named ‘timm’的错误解决

《Python中ModuleNotFoundError:Nomodulenamed‘timm’的错误解决》本文主要介绍了Python中ModuleNotFoundError:Nomodulen... 目录一、引言二、错误原因分析三、解决办法1.安装timm模块2. 检查python环境3. 解决安装路径问题

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错