当前位置:首页 > 科技  > 软件

揭示Lombok的代码设计缺陷:探索封装问题

来源: 责编: 时间:2023-10-23 17:05:40 416观看
导读译者 | 李睿审校 | 重楼 在不断发展的Java开发世界中,开发人员不断寻找工具和代码库来简化代码编写过程。其中一个工具是Project Lombok,通常简称为Lombok。这个Java库提供了代码生成功能,有望简化开发人员的工作。然而,

译者 | 李睿GrM28资讯网——每日最新资讯28at.com

审校 | 重楼 GrM28资讯网——每日最新资讯28at.com

在不断发展的Java开发世界中,开发人员不断寻找工具和代码库来简化代码编写过程。其中一个工具是Project Lombok,通常简称为Lombok。这个Java库提供了代码生成功能,有望简化开发人员的工作。然而,与任何强大的工具一样,也需要注意避开一些设计缺陷。GrM28资讯网——每日最新资讯28at.com

GrM28资讯网——每日最新资讯28at.com

本文将以Lombok为重点深入研究代码设计的世界,探讨Lombok看似方便的注释(例如Builder和Log)可能并不像看起来那么完美的原因。此外还将强调封装的重要性,并讨论Lombok的Data和NotNull注释如何导致意想不到的挑战。无论是经验丰富的开发人员还是开始走上编码之旅的新手,本文都将提供具有价值的见解,以增强他们的工程技能。GrM28资讯网——每日最新资讯28at.com

Lombok的优点

在深入研究潜在的缺陷之前,有必要认识到Lombok的优点。Lombok提供了几个可以显著简化代码编写的注释:GrM28资讯网——每日最新资讯28at.com

  • Log注释:Lombok的Log注释允许开发人员快速生成日志代码,减少对样板代码的需求。
  • Builder注释Builder注释通过开发增强代码可读性的构建器方法,简化了复杂对象的创建。

封装的挑战

Lombok的应用并不是一帆风顺的。Lombok带来的最重要的挑战之一与封装概念有关。封装是面向对象编程的基本原则,强调将数据(属性)和对数据进行操作的方法(函数)捆绑到一个称为类的单元中。它有助于维护数据完整性,并保护数据免受未经授权的访问。GrM28资讯网——每日最新资讯28at.com

  • 数据注释:Lombok的数据注释虽然看起来很方便,但可能导致“贫血模型”贫血模型是一个术语,用于描述主要存储几乎没有行为的数据的对象。该注释为类中的所有字段生成getter和setter方法,通过将内部状态暴露给外部操作,有效地破坏了封装。

考虑这样一个场景,其中有一个带有敏感信息(如密码字段)的User类。应用Data注释将自动为密码字段生成getter和setter方法,从而可能允许对敏感数据进行未经授权的访问。这可能导致安全漏洞和数据完整性问题。GrM28资讯网——每日最新资讯28at.com

  • NotNull注释:另一个挑战来自Lombok的NotNull注释。这里给出的建议是一些来自Java 8的带有Objects.requireNonNull的显式API。

为了解决Null值的问题,Java8和更高版本提供了一个内置的解决方案。Objects.requireOnNull方法允许开发人员显式检查Null值,并在遇到Null值时抛出NullPointerException。这种方法提供了一种清晰简洁的方法来处理Null检查,确保基本字段不会未初始化。GrM28资讯网——每日最新资讯28at.com

以下是如何使用Objects.requireOnNull的示例:GrM28资讯网——每日最新资讯28at.com

Java  public void setUser(User user) { this.user = Objects.requireNonNull(user, "User must not be null"); }

通过使用Objects.requireOnNull,开发人员可以更稳健地执行Null检查,即使不依赖Lombok的NotNull注释。GrM28资讯网——每日最新资讯28at.com

增强代码模板和IDE支持

同样需要注意的是,即使不使用Lombok,开发团队也可以在集成开发环境(IDE)中增强代码模板。例如,流行的Java IDE IntelliJ IDEA为生成构建器模式提供了原生支持。开发人员可以创建自定义代码模板,或者使用IDE特定的功能来生成符合他们首选编码标准的代码。GrM28资讯网——每日最新资讯28at.com

通过利用IDE特性和定制模板,开发团队可以获得Lombok的许多好处,例如减少样板代码和改进代码可读性,同时保持对生成代码的完全控制。GrM28资讯网——每日最新资讯28at.com

执行最佳实践的挑战

在理想情况下,开发人员可以使用像Arch Unit这样的工具来强制执行编码最佳实践,并防止使用不安全的注释。然而,事实表明,这说起来容易做起来难。通过自动化工具避免特定的Lombok注释可能面临挑战或限制。这给代码审查和开发人员带来了更大的责任,以捕捉和纠正潜在的问题。GrM28资讯网——每日最新资讯28at.com

使用Lombok的权衡

像任何工具一样,Lombok从代码设计的角度进行了权衡。它提供了便利,并减少了样板代码,但是也会给数据封装带来风险,并且在代码审查期间需要额外的警惕。在项目中使用Lombok的决定应该经过深思熟虑,需要考虑应用程序的特定需求以及开发团队对Lombok的特性和潜在缺陷的熟悉程度。GrM28资讯网——每日最新资讯28at.com

结语

总之,Lombok是一个强大的工具,可以显著提高Java开发中的代码可读性,并减少样板代码。但是必须谨慎使用它,特别是在数据封装方面。了解潜在的缺陷(例如Data和NotNull注释)对于维护代码完整性和安全性至关重要。GrM28资讯网——每日最新资讯28at.com

与开发人员工具箱中的任何工具一样,应该谨慎地使用Lombok,仔细考虑它的优点和缺点。充分了解Lombok的方法可以帮助用户利用它的优势,同时降低风险,最终生成更可维护和更安全的Java代码。GrM28资讯网——每日最新资讯28at.com

因此,在Java项目中使用Lombok之前,需要记住揭示其代码设计缺陷并做出明智的决策,以提高工程技能并确保代码库的完整性。GrM28资讯网——每日最新资讯28at.com

原文标题:Unraveling Lombok's Code Design Pitfalls: Exploring Encapsulation Issues,作者:Otavio SantanaGrM28资讯网——每日最新资讯28at.com


GrM28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-14585-0.html揭示Lombok的代码设计缺陷:探索封装问题

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 你的 JavaScript 正在泄漏内存而你却不知道

下一篇: private final、@Autowired、@Resource你更喜欢哪个?

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • Redmi Buds 4开箱简评:才199还有降噪 可以无脑入

    在上个月举办的Redmi Note11T Pro系列新机发布会上,除了两款手机新品之外,Redmi还带来了两款TWS真无线蓝牙耳机产品,Redmi Buds 4和Redmi Buds 4 Pro,此前我们在Redmi Note11T
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 6月安卓手机好评榜:魅族20 Pro蝉联冠军

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年6月1日至6月30日,仅限国内市场。第一名:魅族20 Pro好评率:95%5月份的时候魅族20 Pro就是
  • 太卷!Redmi MAX 100英寸电视便宜了:12999元买Redmi史上最大屏

    8月5日消息,从小米商城了解到,Redmi MAX 100英寸巨屏电视日前迎来官方优惠,到手价12999元,比发布价便宜了7000元,在大屏电视市场开卷。据了解,Redmi MAX 100
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • 让我们一起聊聊文件的操作

    文件【1】文件是什么?文件是保存数据的地方,是数据源的一种,比如大家经常使用的word文档、txt文件、excel文件、jpg文件...都是文件。文件最主要的作用就是保存数据,它既可以保
  • 如何通过Python线程池实现异步编程?

    线程池的概念和基本原理线程池是一种并发处理机制,它可以在程序启动时创建一组线程,并将它们置于等待任务的状态。当任务到达时,线程池中的某个线程会被唤醒并执行任务,执行完任
  • 消费结构调整丨巨头低价博弈,拼多多还卷得动吗?

    来源:征探财经作者:陈香羽随着流量红利的退潮,电商的存量博弈越来越明显。曾经主攻中高端与品质的淘宝天猫、京东重拾“低价”口号。而过去与他们错位竞争的拼多多,靠
Top