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

Lombok 与 EasyExcel 兼容性问题解析及建议

在 Java 开发中,Lombok 被广泛用于减少样板代码,如 Getter、Setter、构造函数等。然而,在与像 EasyExcel 这样依赖反射机制的库一起使用时,可能会遇到一些意想不到的问题。本文将深入探讨 Lombok 与 EasyExcel 之间的兼容性问题,分析原因,并提供相应的解决方案和建议。

简单版

如果是需要映射的实体类,老老实实的不要去用Lombok的注解,不要去用就对了,不用就没有兼容性或者其他可能的冲突。

一、问题背景

在使用 Lombok 的 @Getter@Setter 注解简化代码时,开发者可能会发现:

  • EasyExcel 无法正确赋值对象的属性,读取的结果为 null
  • 反射调用失败,导致数据解析错误或抛出异常。

这种情况尤其常见于使用 Lombok 自动生成的 Getter 和 Setter 方法与 EasyExcel 等依赖反射的库结合使用时。

二、Lombok 的工作原理

Lombok 通过在编译期修改抽象语法树(AST),为类生成必要的代码,如 Getter、Setter、构造函数等。这意味着:

  • Lombok 并不会在源码中显式地生成方法,而是在编译后的字节码中添加。
  • IDE 需要安装 Lombok 插件才能在编辑器中正确解析 Lombok 注解,否则可能会报错或无法自动完成。

三、EasyExcel 的反射机制

EasyExcel 在读取和写入 Excel 文件时,依赖 Java 的反射机制来:

  • 根据属性的 Getter 和 Setter 方法进行赋值和取值。
  • 要求方法命名符合 JavaBean 规范,如 getXxx()setXxx()

如果反射机制无法正确找到或访问这些方法,就会导致数据无法正确解析或写入。

四、问题原因分析

  1. Lombok 生成的方法在运行时不可见

    • 如果 Lombok 未正确配置,编译器可能不会生成预期的 Getter 和 Setter 方法。
    • 运行时反射无法找到对应的方法,导致属性赋值失败。
  2. 方法可见性或命名不符合规范

    • Lombok 生成的方法可能由于配置不当,导致访问权限不是 public
    • 方法命名不符合 JavaBean 规范,反射无法识别。
  3. IDE 或构建工具未正确配置 Lombok

    • 缺少 Lombok 插件,导致编译器或编辑器无法正确处理 Lombok 注解。
    • 构建工具(如 Maven、Gradle)中未正确添加 Lombok 依赖。
  4. 使用了 Lombok 的特定特性

    • 使用了 Lombok 的 @Accessors@Builder 等注解,更改了方法的生成方式或命名,影响反射访问。

五、解决方案和建议

1. 手动编写 Getter 和 Setter 方法

建议:对于需要被反射访问的属性,手动编写标准的 Getter 和 Setter 方法

public class ProductRankImportExcelVO {private BigDecimal grossProfit;public BigDecimal getGrossProfit() {return grossProfit;}public void setGrossProfit(BigDecimal grossProfit) {this.grossProfit = grossProfit;}// 其他属性...
}

优点

  • 确保方法的可见性和命名符合 JavaBean 规范。
  • 避免 Lombok 可能带来的编译或运行时问题。

2. 确保 Lombok 正确配置

  • 安装 IDE 插件:确保在使用的 IDE(如 IntelliJ IDEA、Eclipse)中安装了 Lombok 插件。

  • 构建工具依赖:在 Maven 或 Gradle 配置中正确添加 Lombok 依赖。

    <!-- Maven 依赖示例 -->
    <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.24</version><scope>provided</scope>
    </dependency>
    

3. 使用 Delombok 检查生成代码

Delombok 是 Lombok 提供的工具,可以展开 Lombok 注解,生成实际的源码。

步骤

  1. 运行 Delombok:使用 Lombok 提供的命令行工具或在 IDE 中运行 Delombok。
  2. 检查生成代码:查看生成的 Getter、Setter 方法是否正确,命名和可见性是否符合要求。
  3. 调整代码:根据生成结果,调整 Lombok 注解或手动编写必要的方法。

4. 避免使用复杂的 Lombok 特性

  • 谨慎使用 @Accessors:该注解可以自定义 Getter、Setter 的生成方式,可能影响方法命名。

    @Accessors(fluent = true)
    private String name;
    // 会生成 name() 和 name(String name) 方法,而非 getName()、setName()
    
  • 避免影响反射的方法生成:尽量使用基本的 Lombok 注解,如 @Getter@Setter,并确保生成的方法符合规范。

5. 检查方法的可见性和命名

  • 方法应为 public 访问级别
  • 符合 JavaBean 规范:方法命名应为 getXxx()setXxx(),其中 Xxx 为属性名,首字母大写。

6. 确保属性和方法类型一致

  • 类型匹配:Setter 方法的参数类型应与属性类型一致。
  • 避免方法重载:不要对 Getter、Setter 方法进行重载,防止反射机制混淆。

7. 测试和验证

  • 单元测试:编写测试用例,验证属性能否正确赋值和取值。
  • 调试模式:在运行时调试,查看反射调用是否成功,有无异常抛出。

六、示例演示

问题复现

@Data // Lombok 注解
public class ProductRankImportExcelVO {private BigDecimal grossProfit;// 其他属性...
}// 读取 Excel
List<ProductRankImportExcelVO> productList = ExcelUtils.read(bytes, "产品", ProductRankImportExcelVO.class);
// 结果:productList 的 grossProfit 属性全为 null

解决方案

public class ProductRankImportExcelVO {private BigDecimal grossProfit;public BigDecimal getGrossProfit() {return grossProfit;}public void setGrossProfit(BigDecimal grossProfit) {this.grossProfit = grossProfit;}// 其他属性...
}// 重新读取 Excel
List<ProductRankImportExcelVO> productList = ExcelUtils.read(bytes, "产品", ProductRankImportExcelVO.class);
// 结果:grossProfit 属性成功赋值

七、总结

在使用 Lombok 与 EasyExcel 等依赖反射机制的库时,需要注意:

  • 手动编写关键属性的 Getter 和 Setter 方法,确保方法可被反射访问。
  • 正确配置 Lombok,包括 IDE 插件和构建工具依赖,确保方法正确生成。
  • 遵循 JavaBean 规范,方法命名和可见性应符合要求。
  • 谨慎使用 Lombok 的高级特性,避免更改方法的生成方式或命名。

通过上述措施,可以有效解决 Lombok 与 EasyExcel 的兼容性问题,确保数据解析和处理的正确性。

八、建议

  • 权衡 Lombok 的使用:虽然 Lombok 可以减少样板代码,但在关键场景下,手动编写代码可以提高可靠性和可读性。
  • 统一团队规范:在团队中制定 Lombok 的使用规范,明确在哪些情况下可以使用 Lombok,哪些情况下应手动编码。
  • 持续学习和关注:保持对 Lombok 和 EasyExcel 等库的更新和社区讨论的关注,及时了解可能的兼容性问题和解决方案。

希望本文能帮助您深入理解 Lombok 与 EasyExcel 的兼容性问题,并在实际开发中加以注意,避免类似问题的发生。如有任何疑问,欢迎交流讨论!

相关文章:

Lombok 与 EasyExcel 兼容性问题解析及建议

在 Java 开发中&#xff0c;Lombok 被广泛用于减少样板代码&#xff0c;如 Getter、Setter、构造函数等。然而&#xff0c;在与像 EasyExcel 这样依赖反射机制的库一起使用时&#xff0c;可能会遇到一些意想不到的问题。本文将深入探讨 Lombok 与 EasyExcel 之间的兼容性问题&a…...

Kubeadm快速安装 Kubernetes集群

1. Kubernetes简介 Kubernetes&#xff08;k8s&#xff09;是谷歌开源的容器编排平台&#xff0c;用于自动化部署、扩展和管理容器化应用程序。它具有以下特点&#xff1a; 开源容器化自动部署扩展高可用 2. Kubernetes架构 Kubernetes遵循主从式架构设计&#xff0c;主要分…...

OpenJudge | 八皇后问题

总时间限制: 10000ms 内存限制: 65536kB 描述 在国际象棋棋盘上放置八个皇后&#xff0c;要求每两个皇后之间不能直接吃掉对方。 输入 无输入。 输出 按给定顺序和格式输出所有八皇后问题的解&#xff08;见Sample Output&#xff09;。 样例输入 (null)样例输出 No. 1 …...

C#往压缩包Zip文件的文件追加数据

C#往压缩包Zip文件的文件追加数据 往一个已经压缩好的压缩包里追加数据,一般就有两种方式,一种是前面已经学习过的,就是追加一个新的文件, 另外一种就是往已经存在的文件追加数据。 往已经存在的文件追加数据,需要先找到文件索引。 在压缩包里声明的名称,与外面的文件路…...

局域网共享文件夹:您没有权限访问,请与网络管理员联系

局域网共享文件夹&#xff1a;您没有权限访问&#xff0c;请与网络管理员联系 win10 1909 专业版背景 我有两个电脑&#xff0c;还有两块外挂硬盘&#xff0c;较大的一块放在老电脑上&#xff0c;为了方便用垃圾百度网盘在里边下载东西&#xff0c;又不污染新电脑的环境。 如…...

科技修复记忆:轻松几步,旧照变清晰

在时间的长河中&#xff0c;旧照片承载着无数珍贵的记忆与故事。然而&#xff0c;随着岁月的流逝&#xff0c;这些照片往往变得模糊不清&#xff0c;色彩黯淡&#xff0c;令人惋惜。 幸运的是&#xff0c;随着科技的发展&#xff0c;我们有了多种方法来修复这些旧照片的画质&a…...

java -versionbash:/usr/lib/jvm/jdk1.8.0_162/bin/java:无法执行二进制文件:可执行文件格式错误

实验环境&#xff1a;Apple M1在VMwareFusion使用Utubun Jdk文件错误 &#xfffc; 尝试&#xff1a; 1、重新在网盘下载java1.8 2、在终端通过命令下载 3、确保 JDK 正确安装在系统中&#xff0c;可以通过 echo $JAVA_HOME 检查 JAVA_HOME 环境变量是否设置正确。 &#xfff…...

大数据-141 - ClickHouse 集群 副本和分片 Zk 的配置 Replicated MergeTree原理详解

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…...

Django-cookie和session

文章目录 前言CookieSession 一、Django 中 Cookie二、Django 中 Session三.区别 前言 Cookie Cookie 是由服务器发送到用户浏览器的小文件&#xff0c;用于存储用户的相关信息。每次用户访问网站时&#xff0c;浏览器会将这些 cookie 发送回服务器 特点: 1. 数据存储在客户…...

前端进阶,使用Node.js做中间层,实现接口转发和服务器渲染

在Web开发中&#xff0c;Node.js经常被用作中间层&#xff08;也称为后端或服务器端&#xff09;&#xff0c;用于处理各种任务&#xff0c;包括接口转发&#xff08;API Gateway&#xff09;、服务器渲染&#xff08;Server-Side Rendering, SSR&#xff09;等。下面我将分别解…...

iPhone 16系列:熟悉的味道,全新的体验

来看看iPhone 16和Plus这两个新成员&#xff0c;实话说&#xff0c;它们和之前曝光的样子几乎完全一致。下面我们就一起来细数一下这次的几大变化吧。 外观设计&#xff1a;焕然一新 首先&#xff0c;最显眼的变化就是后置镜头模组的布局调整为了垂直排列。这一改变使得整个背…...

改进拖放PDF转换为图片在转换为TXT文件的程序

前段时间我写了Python识别拖放的PDF文件再转成文本文件-CSDN博客 最近有2点更新&#xff0c;一是有一些pdf文件转换出来的图片是横的&#xff0c;这样也可以识别文字&#xff0c;但是可能会影响效果&#xff0c;另一个是发现有一些文字识别不出来&#xff0c;看了关于提高Padd…...

在 Flutter 开发中如何选择状态管理:Provider 和 GetX 比较

在 Flutter 开发中&#xff0c;状态管理是一个至关重要的部分。正确的状态管理方案能够提高应用的可维护性和可扩展性。在众多状态管理方案中&#xff0c;Provider 和 GetX 是两种非常流行的选择。本文将对这两者进行比较&#xff0c;并提供代码示例&#xff0c;以帮助开发者选…...

python中ocr图片文字识别样例(二)

一、说明 本次解决图片相关出现中文乱码问题&#xff0c;属于上篇文章的优化&#xff0c;前提条件依赖上篇文章的包&#xff0c;当然ocr的具体应用场景很多&#xff0c;根据自身需求进行调整 二、具体实现 2.1 代码实现&#xff1a; # -*- coding: utf-8 -*- import easyoc…...

2024 新手指南:轻松掌握 Win10 的录屏操作

之前为了节约成本我们公司都采用录制软件操作都方式来为异地的同事进行远程操作培训的。所以我们尝试了不少的录屏工具&#xff0c;这里我就分享下win10怎么录屏的操作过程。 1.福昕录屏大师 链接&#xff1a;www.foxitsoftware.cn/REC/ 这款录屏工具是初学者的理想之选&…...

无人机黑飞打击技术详解

随着无人机技术的普及&#xff0c;无人机“黑飞”&#xff08;未经授权或违反规定的飞行&#xff09;现象日益严重&#xff0c;对公共安全、隐私保护及重要设施安全构成了严重威胁。为有效应对这一挑战&#xff0c;各国政府和安全机构纷纷研发并部署了一系列无人机黑飞打击技术…...

GoFly快速开发框架/Go语言封装的图像相似性比较插件使用说明

说明 图像相似性搜索应用广泛、除了使用搜索引擎搜索类似图片外&#xff0c;像淘宝可以让顾客直接拍照搜索类似的商品信息、应用在商品购物上&#xff0c;也可以应用物体识别比如拍图识花等领域。还有在调研图片鉴权的方案&#xff0c;通过一张图片和图片库中的图片进行比对&a…...

【牛客】小白赛101-B--tb的字符串问题

题目传送门 思路&#xff1a;括号匹配板子 反思&#xff1a;我用了模拟打标记的方式但是还是wa了 ac代码 用了栈维护 当栈里面个数到达1个以上的时候就可以判断栈顶是否匹配然后重复出入栈操作 #include<bits/stdc.h> using namespace std; const int N1e63; string…...

企业专用智能云盘 | 帮助企业便捷管控企业文档 | 天锐绿盘云文档安全管理系统

由于当前多数企业内部的办公文件普遍散落于各员工电脑中&#xff0c;导致存在诸多潜在的文档使用风险。为优化团队协作效率&#xff0c;天 锐 绿盘是一款集文档统一管理、高效协同于一体的企业云盘&#xff0c;帮助企业解决文档管理中的诸多难题。 【地址&#xff1a;点击了解天…...

软件工程专业未来发展方向

1. 前端开发&#xff08;Front-end Development&#xff09; 简介&#xff1a; 前端开发者专注于网站和应用程序的用户界面和用户体验设计。他们使用HTML、CSS、JavaScript等基本技术&#xff0c;以及React、Angular、Vue.js等前端框架&#xff0c;来创建互动性强、响应迅速的…...

利用ngx_stream_return_module构建简易 TCP/UDP 响应网关

一、模块概述 ngx_stream_return_module 提供了一个极简的指令&#xff1a; return <value>;在收到客户端连接后&#xff0c;立即将 <value> 写回并关闭连接。<value> 支持内嵌文本和内置变量&#xff08;如 $time_iso8601、$remote_addr 等&#xff09;&a…...

Unity3D中Gfx.WaitForPresent优化方案

前言 在Unity中&#xff0c;Gfx.WaitForPresent占用CPU过高通常表示主线程在等待GPU完成渲染&#xff08;即CPU被阻塞&#xff09;&#xff0c;这表明存在GPU瓶颈或垂直同步/帧率设置问题。以下是系统的优化方案&#xff1a; 对惹&#xff0c;这里有一个游戏开发交流小组&…...

循环冗余码校验CRC码 算法步骤+详细实例计算

通信过程&#xff1a;&#xff08;白话解释&#xff09; 我们将原始待发送的消息称为 M M M&#xff0c;依据发送接收消息双方约定的生成多项式 G ( x ) G(x) G(x)&#xff08;意思就是 G &#xff08; x ) G&#xff08;x) G&#xff08;x) 是已知的&#xff09;&#xff0…...

Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务

通过akshare库&#xff0c;获取股票数据&#xff0c;并生成TabPFN这个模型 可以识别、处理的格式&#xff0c;写一个完整的预处理示例&#xff0c;并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务&#xff0c;进行预测并输…...

Python爬虫(二):爬虫完整流程

爬虫完整流程详解&#xff08;7大核心步骤实战技巧&#xff09; 一、爬虫完整工作流程 以下是爬虫开发的完整流程&#xff0c;我将结合具体技术点和实战经验展开说明&#xff1a; 1. 目标分析与前期准备 网站技术分析&#xff1a; 使用浏览器开发者工具&#xff08;F12&…...

如何理解 IP 数据报中的 TTL?

目录 前言理解 前言 面试灵魂一问&#xff1a;说说对 IP 数据报中 TTL 的理解&#xff1f;我们都知道&#xff0c;IP 数据报由首部和数据两部分组成&#xff0c;首部又分为两部分&#xff1a;固定部分和可变部分&#xff0c;共占 20 字节&#xff0c;而即将讨论的 TTL 就位于首…...

接口自动化测试:HttpRunner基础

相关文档 HttpRunner V3.x中文文档 HttpRunner 用户指南 使用HttpRunner 3.x实现接口自动化测试 HttpRunner介绍 HttpRunner 是一个开源的 API 测试工具&#xff0c;支持 HTTP(S)/HTTP2/WebSocket/RPC 等网络协议&#xff0c;涵盖接口测试、性能测试、数字体验监测等测试类型…...

【堆垛策略】设计方法

堆垛策略的设计是积木堆叠系统的核心&#xff0c;直接影响堆叠的稳定性、效率和容错能力。以下是分层次的堆垛策略设计方法&#xff0c;涵盖基础规则、优化算法和容错机制&#xff1a; 1. 基础堆垛规则 (1) 物理稳定性优先 重心原则&#xff1a; 大尺寸/重量积木在下&#xf…...

DeepSeek越强,Kimi越慌?

被DeepSeek吊打的Kimi&#xff0c;还有多少人在用&#xff1f; 去年&#xff0c;月之暗面创始人杨植麟别提有多风光了。90后清华学霸&#xff0c;国产大模型六小虎之一&#xff0c;手握十几亿美金的融资。旗下的AI助手Kimi烧钱如流水&#xff0c;单月光是投流就花费2个亿。 疯…...

AWS vs 阿里云:功能、服务与性能对比指南

在云计算领域&#xff0c;Amazon Web Services (AWS) 和阿里云 (Alibaba Cloud) 是全球领先的提供商&#xff0c;各自在功能范围、服务生态系统、性能表现和适用场景上具有独特优势。基于提供的引用[1]-[5]&#xff0c;我将从功能、服务和性能三个方面进行结构化对比分析&#…...