@Slf4j vs LoggerFactory.getLogger(): 日志记录方式的对比与选择

前言

在Java开发中,日志记录是追踪系统行为、诊断问题和监控应用性能的关键工具。SLF4J(Simple Logging Facade for Java)作为一款流行的日志门面库,提供了统一的日志API,允许开发者灵活地对接多种底层日志实现。本文将详细对比使用@Slf4j注解与LoggerFactory.getLogger()这两种SLF4J提供的日志记录方式,并探讨它们的作用、用法及适用场景。

1. @Slf4j注解

作用与用法

@Slf4j是Lombok库提供的一种注解,用于简化日志记录的初始化和使用。当你在类上添加@Slf4j注解时,Lombok会在编译阶段自动生成一个名为logLogger实例变量,并自动调用LoggerFactory.getLogger()方法初始化该实例。这意味着你无需手动编写如下代码:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;public class MyClass {private static final Logger logger = LoggerFactory.getLogger(MyClass.class);// ...
}

取而代之,只需在类声明处添加@Slf4j注解:

import lombok.extern.slf4j.Slf4j;@Slf4j
public class MyClass {// ...
}

随后即可在类的方法中直接使用log对象进行日志记录:

public void someMethod() {log.info("Some information message");log.debug("Debugging details");log.warn("A warning message");// ...
}

优点

  • 简洁性:省去了手动创建和初始化Logger对象的代码,使代码更干净、更专注于业务逻辑。
  • 一致性:为所有使用@Slf4j注解的类自动生成同名的log变量,增强了代码风格的一致性。
  • 编译时生成:Lombok的处理发生在编译时,不会增加运行时负担,同时避免了手动初始化可能引入的错误。

适用场景

  • 追求代码简洁与规范:在项目中广泛采用Lombok库,希望减少样板代码,保持代码风格一致的团队。
  • 新项目或重构:在项目初期或进行代码重构时,利用@Slf4j可以快速地为所有类添加日志支持。

2. LoggerFactory.getLogger()

作用与用法

LoggerFactory.getLogger()是SLF4J API提供的标准方法,用于创建或获取与特定类关联的Logger实例。使用时,你需要手动编写如下代码:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;public class MyClass {private static final Logger logger = LoggerFactory.getLogger(MyClass.class);public void someMethod() {logger.info("Some information message");logger.debug("Debugging details");logger.warn("A warning message");// ...}
}

这里,getLogger()方法接受一个类的Class对象作为参数,通常传入this.getClass()MyClass.class。这样,日志输出时会自动包含类名信息,有助于在日志中快速识别日志来源。

优点

  • 灵活性:无需依赖Lombok库,适用于不能或不愿引入Lombok的项目。
  • 显式控制:手动初始化Logger对象使得日志创建过程更为明确,便于理解和控制。

适用场景

  • 现有项目:已有的项目结构中没有使用Lombok,或者出于某些原因(如IDE支持、团队偏好等)不打算引入Lombok。
  • 低依赖要求:对于那些力求最小化第三方库依赖的轻量级应用,直接使用LoggerFactory.getLogger()可以避免引入Lombok。

3. 对比与选择

@Slf4j与**LoggerFactory.getLogger()**本质上都是使用SLF4J API进行日志记录,只是在初始化Logger对象的方式上有所不同:

  • @Slf4j借助Lombok的编译时代码生成能力,实现了日志对象的自动初始化,提供了更为简洁、一致的编程体验,特别适合与Lombok库深度集成的项目。
  • **LoggerFactory.getLogger()**则是SLF4J原生的、无需额外库支持的日志初始化方式,虽然略显冗长,但对于那些不需要或无法引入Lombok的场景,它提供了直接、灵活且易于理解的日志记录解决方案。

在实际开发中,选择哪种方式取决于项目的具体需求、技术栈偏好以及团队约定。如果你的项目已经采用了Lombok,并且团队愿意接受其带来的代码风格改变,那么@Slf4j无疑是更优的选择。反之,如果倾向于保持较低的第三方库依赖,或者团队成员对Lombok的使用尚存争议,直接使用LoggerFactory.getLogger()不失为一种稳健且易于维护的日志记录方式。无论选择哪一种,SLF4J提供的强大日志功能和与多种底层日志系统的无缝对接能力都能为你的项目保驾护航。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/313608.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

统一所有 LLM API:支持预算与速率限制 | 开源日报 No.229

BerriAI/litellm Stars: 6.7k License: NOASSERTION litellm 是一个使用 OpenAI 格式调用所有 LLM API 的工具。它支持 Bedrock、Azure、OpenAI、Cohere、Anthropic 等 100 多种 LLMs,提供企业级代理服务器和稳定版本 v1.30.2。 主要功能和优势包括: 将…

探索大型语言模型(LLM)在人类性格个性评估(MBTI)中的前景与应用

1.概述 大型语言模型(LLM)如ChatGPT在各个领域的应用确实越来越广泛,它们利用庞大的数据集进行训练,以模拟人类的语言理解和生成能力。这些模型在提供信息、解答问题、辅助决策等方面表现出了强大的能力,但它们并不具…

[集群聊天项目] muduo网络库

目录 网络服务器编程常用模型什么是muduo网络库什么是epoll muduo网络库服务器编程 网络服务器编程常用模型 【方案1】 : accept read/write 不是并发服务器 【方案2】 : accept fork - process-pre-connection 适合并发连接数不大,计算任…

Yolov5 export.py实现onnx模型的导出

查了很多资料,很多用python代码写的,只需要这个库那个库的,最后都没成功。 不如直接使用Yolov5里面的 export.py实现模型的转换。 一:安装依赖 因为yolov5里面的requirments.txt是将这些转换模型的都注释掉了 所以需要解除注释…

人工智能论文GPT-3(2):2020.5 Language Models are Few-Shot Learners;微调;少样本Few-Shot (FS)

2 方法Approach 我们的基本预训练方法,包括模型、数据和训练,与GPT-2中描述的过程相似,只是模型规模、数据集规模和多样性,以及训练时长有所扩大,相对简单直接。 我们使用的上下文学习也与GPT-2相似,但在…

Kafka 3.x.x 入门到精通(03)——对标尚硅谷Kafka教程

Kafka 3.x.x 入门到精通(03)——对标尚硅谷Kafka教程 2. Kafka基础2.1 集群部署2.2 集群启动2.3 创建主题2.4 生产消息2.4.1 生产消息的基本步骤2.4.2 生产消息的基本代码2.4.3 发送消息2.4.3.1 拦截器2.4.3.1.1 增加拦截器类2.4.3.1.2 配置拦截器 2.4.3…

.NET 邮件发送 SMTP邮件发送

SMTP(Simple Mail Transfer Protocol)是用于电子邮件传输的规则集,可以从邮件客户端向接收电子邮件服务器发送、中继或转发邮件。发件人可使用SMTP 服务器来执行发送电子邮件的过程。SMTP服务器则是按照这些规则中转电子邮件的服务器。 IMAP…

【Qt QML】TabBar的用法

Qt Quick中的TabBar提供了一个基于选项卡的导航模型。TabBar由TabButton控件填充,并且可以与任何提供currentIndex属性的布局或容器控件一起使用,例如StackLayout或SwipeView。 import QtQuick import QtQuick.Controls import QtQuick.LayoutsWindow …

企业微信hook接口协议,ipad协议http,发送大视频文件

发送大视频文件 参数名必选类型说明uuid是String每个实例的唯一标识,根据uuid操作具体企业微信send_userid是long要发送的人或群idisRoom是bool是否是群消息 请求示例 {"uuid":"1688853790xxx", //uuid 默认随机生成如果初始化传了id则用初始…

潜藏10年的恶意软件被发现;利用漏洞在K8S上挖矿;AWS、Google和Azure 出现信息泄露危机 | 安全周报0419

关键词:OfflRouter、恶意软件、VBA宏病毒、机密文件、可执行文件、iOS间谍软件、LightSpy、F_Warehouse、Azure CLI、AWS CLI、Google Cloud CLI 1. 近十年来,OfflRouter恶意软件在乌克兰一直未被发现 自2015年以来,部分乌克兰政府网络一直…

【学习】如何高效地进行集成测试

在软件开发的过程中,测试环节至关重要。而在这其中,集成测试更是保证软件质量的关键步骤之一。本文将探讨如何高效地进行集成测试,以确保软件的稳定性和可靠性。 一、什么是集成测试 集成测试是指在单元测试的基础上,将模块按照设…

力扣刷题学习(跟随视频学着刷)

使用入门 视频链接 【手把手带你刷Leetcode力扣|各个击破数据结构和算法|大厂面试必备技能【已完结】-哔哩哔哩】 https://b23.tv/vIcRT61 时空复杂度 时间: 空间:主要有O(1)和O(n)两种,只用计算开辟的内存&#xff…

cdp集群Hbase组件HRegionServer服务停止原因以及排查

前言:重启集群后某一节点HRegionServer服务停止,重启前所有服务均正常 去查看日志: 日志报错 ERROR HRegionServer Master rejected startup because clock is out of sync org.apache.hadoop.hbase.ClockOutOfSyncException: org.apache.h…

【Python】异常、模块与包

目录 捕获异常 异常的传递 Python中的模块 模块的导入方式 as定义别名 自定义模块 Python包 第三方包 综合案例 当我们的程序遇到了BUG, 那么接下来有两种情况: ① 整个程序因为一个BUG停止运行 ② 对BUG进行提醒, 整个程序继续运行 但是在真实工作中, 我们肯定不能…

第十五届蓝桥杯省赛第二场C/C++B组D题【前缀总分】题解(AC)

暴力解法 O ( 26 n 5 ) O(26n^5) O(26n5) 枚举将第 i i i 个字符串的第 j j j 个字符改为 c c c 的所有方案,时间复杂度 O ( 26 n 2 ) O(26n^2) O(26n2),修改并计算总分, O ( n 3 ) O(n^3) O(n3)。 暴力优化 O ( 26 n 3 log ⁡ n ) O…

【Pytorch】(十四)C++ 加载TorchScript 模型

文章目录 (十四)C 加载TorchScript 模型Step 1: 将PyTorch模型转换为TorchScriptStep 2: 将TorchScript序列化为文件Step 3: C程序中加载TorchScript模型Step 4: C程序中运行TorchScript模型 【Pytorch】(十三)PyTorch模型部署: T…

什么是langchain

概念 LangChain 是一个用于开发由语言模型驱动的应用程序的框架。他主要拥有 2 个能力: -可以将 LLM 模型(大规模语言模型)与外部数据源进行连接 -允许与 LLM 模型进行交互基础功能 支持多种模型接口,比如 OpenAI、Hugging Fac…

Delta模拟器:iOS上的复古游戏天堂

Delta模拟器:iOS上的复古游戏天堂 在数字时代,我们有时会怀念起那些早期的电子游戏,它们简单、纯粹,带给我们无尽的乐趣。虽然现在的游戏在画质和玩法上都有了巨大的提升,但那种复古的感觉却始终无法替代。幸运的是&a…

Ceph 分布式文件系统 搭建及使用

一、Ceph 介绍 在当今数据爆炸式增长的时代,企业对于可靠、可扩展的存储解决方案的需求日益迫切。Ceph 作为一种开源的、可伸缩的分布式存储解决方案,正逐渐成为企业级存储领域的热门选择。Ceph是一种由Radicalbit公司开发的开源分布式存储系统&#xf…

公网IP地址如何申请SSL证书?有免费的IP ssl吗?

如果用户没有域名或只有公网IP地址或者不方便使用域名,IP地址ssl证书这一特殊的证书可以为IP地址实现HTTPS的安全保护,提高网站数据传输的安全性。 IP地址申请SSL证书的基本步骤 IP ssl证书下载---注册填写230916https://www.joyssl.com/certificate/sel…