如何用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

相关文章

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

C#实现获取电脑中的端口号和硬件信息

《C#实现获取电脑中的端口号和硬件信息》这篇文章主要为大家详细介绍了C#实现获取电脑中的端口号和硬件信息的相关方法,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。那么如果我们使用C#编写软件时候,如

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

Java操作PDF文件实现签订电子合同详细教程

《Java操作PDF文件实现签订电子合同详细教程》:本文主要介绍如何在PDF中加入电子签章与电子签名的过程,包括编写Word文件、生成PDF、为PDF格式做表单、为表单赋值、生成文档以及上传到OB... 目录前言:先看效果:1.编写word文件1.2然后生成PDF格式进行保存1.3我这里是将文件保存到本地后

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用