0

0

如何在Java中通过抽象类统一不同子类的日志行为

P粉602998670

P粉602998670

发布时间:2026-02-18 13:14:02

|

696人浏览过

|

来源于php中文网

原创

应在抽象类中使用final模板方法executewithlogging()封装日志逻辑,强制子类执行「记录开始→调用dowork()→记录结束/异常」流程;通过getclass().getsimplename()获取子类名,system.nanotime()统计耗时,map透传上下文;移除@slf4j改用protected final logger log = loggerfactory.getlogger(getclass())避免日志类名错误;模板方法中统一warn/error记录异常并原样抛出,禁用e.getmessage()拼接。

如何在java中通过抽象类统一不同子类的日志行为

抽象类里怎么塞日志逻辑才不被子类绕过

直接在抽象类的构造方法或初始化块里写 log.info() 没用——子类可能不调用 super(),或者用的是无参构造,日志就丢了。真正可靠的入口是模板方法:把日志作为骨架流程的一部分,强制子类走这个链路。

  • 定义一个 executeWithLogging() 模板方法,内部完成「记录开始 → 调用抽象方法 doWork() → 记录结束/异常」
  • 子类只管实现 doWork(),不能重写 executeWithLogging()(加 final
  • 如果子类已有业务入口方法(比如 process()),别让它直接暴露;统一重定向到 executeWithLogging()

日志内容怎么带上下文又不耦合子类细节

抽象类不知道子类具体做什么,但能拿到通用信息:类名、线程名、执行耗时。关键是要避免在抽象类里硬编码子类字段或方法,否则一加新子类就得改抽象类。

  • this.getClass().getSimpleName() 获取子类名,比写死字符串更安全
  • 耗时统计用 System.nanoTime(),别用 new Date()(精度低,还创建对象)
  • 想透传业务参数?加一个 Map<string object> context</string> 参数到模板方法,子类调用时自己塞 "orderId""userId" 这类键值,抽象类只负责打日志,不解析
  • 别在抽象类里调 logger.debug("user: " + user.getName()) —— user 可能为 null,且子类字段名未必叫 user

SLF4J + Lombok @Slf4j 一起用会出什么问题

很多团队给抽象类加了 @Slf4j,结果发现日志里输出的类名全是抽象类名(比如 BaseService),不是实际运行的子类名,排查时定位错对象。

今客CRM客户管理系统 v18.1
今客CRM客户管理系统 v18.1

今客CRM客户管理系统主要是为了帮助企业解决在日常工作中遇到的客户管理等难题而开发,通过今客CRM客户管理系统可以对企业事务中的不同功能进行操作,用户通过自定义字段类型可以达到适合不同企业的需求。在今客客户关系管理系统中管理着一个企业最为完整的客户信息,全面的客户信息覆盖在企业的市场营销、销售和服务与技术支持等企业整个前端办公领域的各个环节里。它为企业带来附加价值是不可限量的。今客CRM客户管理系

下载
  • Lombok 的 @Slf4j 在编译期生成 private static final Logger log = LoggerFactory.getLogger(XXX.class),而 XXX 是抽象类本身
  • 解决办法:去掉抽象类上的 @Slf4j,改用 protected final Logger log 字段,在构造方法里赋值 LoggerFactory.getLogger(getClass())
  • 注意:必须是 final + protected,既保证子类能用,又防止被覆盖
  • 如果用了 Logback,还可以配合 %X{traceId} 这类 MDC 字段,但 MDC 的 put()clear() 必须成对出现在模板方法里,否则脏数据会跨请求泄漏

子类抛异常时日志怎么既清晰又不重复打印

常见错误是子类在 doWork() 里自己 try-catch 打了一次日志,模板方法又 catch 一次再打——同一异常出现两行日志,堆栈还可能被截断。

立即学习Java免费学习笔记(深入)”;

  • 抽象类的模板方法只做「捕获、记录、重新抛出」,不要 log.error("xxx", e) 后吞掉异常
  • log.warn("task {} failed", taskName, e),SLF4J 会自动把 e 的完整堆栈写进日志,不用手动 e.printStackTrace()
  • 如果子类真要处理部分异常(比如重试),那就让它抛自定义业务异常(如 RetryableException),抽象类针对这类异常单独打 warn,其他一律打 error
  • 别在抽象类里 e.getMessage() 拼字符串——空指针、中文乱码、敏感信息泄露全在这儿埋雷

最麻烦的其实是日志级别混用:抽象层该用 info 的地方写了 debug,结果线上关了 debug 日志就看不到关键路径;或者子类静默吞了本该上报的 error。这事没法靠语法约束,得靠 Code Review 时盯住每一处 log.xxx() 的调用点。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

770

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

244

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

766

2024.03.01

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

553

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

216

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1553

2023.10.24

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

561

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.7万人学习

C# 教程
C# 教程

共94课时 | 9.7万人学习

Java 教程
Java 教程

共578课时 | 67.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号