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

相关文章

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机