当前位置: 首页 > news >正文

历史项目依赖库Bugfix技巧-类覆盖

在项目维护过程中,我们可能会遇到历史项目依赖的第三方库出现BUG而需要修复的情况,而这些第三方库可能来源于公司自主开发或开源项目,但由于各种原因,这些库可能已无人维护。

此时,解决这个问题有三个办法

1、基于源码修改重新打包发布

2、某些时候可能没有源码,需要反编译进行修改再重新编译打包

3、类覆盖

本文主要分享第三种类覆盖的实现方式,用于在一些特殊情况下解决线上问题,保证项目的正常运行。

一、类覆盖的基本原理

原理如其名,通过自定义类覆盖目标类。

具体实现方式为通过定义与三方库中存在问题目标类同名的自定义类,并确保其加载优先级高于原始类。

这里特别说明下类加载优先级的控制,分两种情况

1. 直接依赖

项目直接依赖了一个库C,项目源码打包后是在classes目录下的,此种情况无需特殊控制,默认classes目录优先加载,因此自定义的类会优先于依赖库中的类加载。

2. 关联依赖

项目依赖了库B,库B又依赖了库C,如果要控制库B和库C中同名类的加载顺序,可以通过定义依赖顺序进行控制。

以SpringBoot Maven 工程为例,B依赖定义在C依赖上面,可以保证最终生成的可执行jar中classpath.idx里面定义的库加载顺序B优先于C,保证最终加载时B库中的类优先于C库加载。

<dependency><groupId>org.example</groupId><artifactId>B</artifactId><version>1.0-SNAPSHOT</version>
</dependency>
<dependency><groupId>org.example</groupId><artifactId>C</artifactId><version>1.0-SNAPSHOT</version>
</dependency>

在这里插入图片描述

二、一个示例

如下工程,有一个依赖的三方库C

在这里插入图片描述

C依赖库种有一个C工具类,代码如下,其中的isEmpty方法未判断null值,会导致空指针异常

package org.c;public class C {public static boolean isEmpty(String s){return s.isEmpty();}}

主模块A类代码如下,调用了C类的isEmpty方法

public class A {public static void main(String[] args ) {String s = "123";if(!C.isEmpty(s)){System.out.println("String is " + s);}String ss = null;if(!C.isEmpty(ss)){ // 异常位置System.out.println("String is " + s);}}}

运行A类将会在异常位置处出现空指针异常。

下面使用类覆盖方法进行BUG修正。

2.1 创建同名类

在A模块种创建同名类C,如下

注意同名类是整个包名 + 类名相同

在这里插入图片描述

自定义C类的代码如下

package org.c;public class C {public static boolean isEmpty(String s){// 修复原始库空指针问题if(s == null) {return true;}return s.isEmpty();}}
2.2 验证效果

再次运行A类,程序正常执行完成。

三、总结

首先,优先推荐前两种方式进行问题修复,但是某些时候受制于时间、成本、风险等因素需要快速解决问题,这时,可以考虑第三种方案类覆盖。

需要特别注意的是,修改的方法可能会被多处调用,修改时需要充分考虑兼容性。

相关文章:

  • 正则表达式详解:从基础到高级应用的全面指南
  • 【文件】Linux 内核优化实战 - fs.inotify.max_user_watches
  • 基本进程调度算法
  • 马斯克YC技术核弹全拆解:Neuralink信号编译器架构·星舰着陆AI代码·AGI防御协议(附可复现算法核心/开源替代方案/中国技术对标路径)
  • anchor 智能合约 IDL 调用
  • 【信创-k8s】银河麒麟V10国防版+鲲鹏/飞腾(arm64架构)在线/离线部署k8s1.30+kubesphere
  • 《汇编语言:基于X86处理器》第4章 数据传送、寻址和算术运算(1)
  • Python----OpenCV(图像増强——图像平滑、均值滤波、高斯滤波、中值滤波、双边滤波)
  • RealSense 相机 | 读取IMU | 解决权限问题 | 提供示例程序
  • 阿里云无影:开启云端办公娱乐新时代
  • Re:从零开始的地址映射基本分页存储管理方式(考研向)
  • 设计模式 - 抽象工厂
  • 域名解析(DNS)相关
  • Typora - Typora 表格删除列与行
  • 光伏电站 “智慧大脑”:安科瑞 Acrel-1000DP 分布式监控系统技术解析
  • react gsap动画库使用详解之text文本动画
  • zlibrary镜像网站,zlibrary中文入口(持续更新)
  • 【Java开发日记】我们详细讲解一下 Java 中 new 一个对象的流程
  • JavaWeb学习——day8(MVC模式与session、cookie)
  • Few-Shot革命:PhotoDoodle艺术图像编辑实战——零样本门槛玩转3D/流体/手绘特效
  • 要做网站照片怎么处理/上街网络推广
  • 机械毕业设计代做网站/google关键词工具
  • 做吉祥物设计看什么网站/郑州seo优化外包公司
  • 做单页网站容易排名吗/seo查询网站
  • 网站策划的最终体现/百度代运营公司
  • 上饶做网站/最近10个新闻