Lombok,自动值和不可变项

我喜欢布兰登(Brandon )在博客文章中比较Project Lombok , AutoValue和Immutables的建议 ,而这篇文章试图做到这一点。 我已经简要概述了Project Lombok , AutoValue和Immutables ,但是这篇文章有所不同,因为它突出了它们之间的异同。

Lombok, AutoValue和Immutables有很多共同点,我尝试在这单个描述语句中总结这些相似之处:Lombok,AutoValue和Immutables使用注释处理为值对象类使用的常见操作生成样板代码。 本文的其余部分将更详细地探讨这些相似之处,并对比三种方法。

代码生成

Lombok,AutoValue和Immutables均旨在从简洁的代码表示形式生成详细的样板代码,这些代码表示形式专注于高级业务逻辑,而将实现的低级细节留给代码生成。 常见的对象方法(例如toString() , equals(Object)和hashCode())很重要,但需要正确编写。 容易犯这些错误,即使最初正确地编写了这些错误(包括通过IDE生成),但在对类产生影响的其他更改时也可以忽略它们。

价值对象

Lombok , AutoValue和Immutables均支持生成“ 值对象” 。 虽然AutoValue严格执行值对象的生成,但是如果指定了@Modifiable ,则Immutables允许生成的对象是可修改的,并且Lombok在其生成的类中使用@Set和@Data等批注支持多级修改。

超越价值对象

AutoValue专注于值对象的生成,并基于模板类中的抽象方法,支持字段,构造器/生成器,具体访问器方法以及常见方法equals(Object)hashCode()toString()的实现的生成。

Immutables提供的功能类似于AutoValue提供的功能,并添加了使用@ Value.Modifiable生成可修改类的功能 。 不可变对象还提供其他功能 ,包括:

  • 单例实例
  • 预先计算的哈希码
  • 实例实习
  • 可自定义的equals(Object),hashCode()和toString()实现,包括从中排除字段
  • 基本和高级序列化

Lombok通过@Value注释提供类似于AutoValue的值类生成功能,并提供通过@Data注释生成可修改类的功能。 Lombok还提供其他功能 ,包括:

  • 资源清理
  • 记录器字段生成
  • 同步对象锁
  • 潜入检查的异常

基于注释处理

Lombok , AutoValue和Immutables都通过注释处理从更简洁的模板代码中生成了更详细的样板代码。 每个都包括在其JAR文件的META-INF/services区域javax.annotation.processing.Processor定义的javax.annotation.processing.Processor ,作为javac编译器一部分的标准注释处理器发现过程的一部分 。

并非所有注释处理都相同

尽管Lombok,AutoValue和Immutables都通过javac进行注释处理 ,但是Lombok如何使用注释处理的细节与AutoValue和Immutables的处理方法不同。 AutoValue和Immutables在更常规的意义上使用注释处理,并从源生成源。 由AutoValue和Immutables生成的类源代码的名称与模板类不同,实际上是扩展了模板类。 AutoValue和Immutables都读取模板类,并在Java源代码中生成一个具有自己名称的全新类,该类具有所有生成的方法和字段。 这避免了与模板类的任何名称冲突,并且使模板类源代码和生成的类源代码在同一IDE项目中的混合相当容易,因为它们实际上是不同的类。

通过注释处理生成AutoValue

20160622-autoValueJavacAnnotationsProcessing.copy

通过注释处理生成不可变对象

20160622-immutablesJavacAnnotations处理

Lombok通过与AutoValue和Immutables不同的批注处理来实现生成。 Lombok生成具有与“模板”源代码相同的类名的已编译.class文件,并将生成的方法添加到此已编译版本中。 开发人员仅在查看.java文件时会看到简洁的模板代码,而在查看.class文件时会看到源代码中不存在的方法的编译后的.class文件。 Lombok生成的不是另一个源文件,而是原始源的增强编译版本。 有一个delombok选项可以与Lombok一起使用,以查看增强的.class文件背后的生成源是什么样子,但是该项目的真正目的是将其从简洁的模板源直接转换为增强的编译类,而无需使用或使用中间的增强功能。源文件。 delombok选项可用于查看生成的源的外观,或者,更重要的是,可以在将其与工具混淆以使源(简洁的.java文件)和生成的类(生成的类)不一致的情况下使用.class同一名称的.class文件)。

Lombok通过注释处理生成

20160622-lombokJavacAnnotations处理

Lombok的注释处理方法不像AutoValue和Immutables所采用的方法那么传统,包括Lombok的创建者在内的一些人将这种方法称为“ hack” 。 Neildo在发布的Lombok – Trick Explained项目中很好地解释了Lombok的“技巧”或“ hack”,并引用了内容丰富的OpenJDK编译概述 。

围绕Lombok的方法引起争议的主要原因是密切相关的,并且它使用的是非标准API,因此很难与IDE和执行自己的编译的其他工具(例如javadoc )很好地集成。 因为AutoValue和Immutables自然会使用新的类名生成源代码,所以任何传统工具和IDE都可以将生成的源代码与模板源代码一起使用,而不会出现任何重大问题。

异同摘要

特性 Lombok计划 自动值 不可变的 注释
涵盖版本 1.16.8 ( 2016年 ) 1.2 ( 2016 ) 2.2.8 (2016年) 此帖子使用的版本
起源年份 2009年 2014年 2014年
执照 麻省理工 ( 也 ) 阿帕奇2 阿帕奇2 全部开源
最低Java 1.6 1.6 1.7 支持的最旧的Java版本
依存关系 ASM ( 用于Eclipse集成 ) ASM (可选) 运行时依赖项 : Guava 编译时依赖(包含)的库
javax.annotation.processing.Processor lombok.launch.AnnotationProcessorHider $ AnnotationProcessor com.google.auto.value.processor.AutoAnnotationProcessor
com.google.auto.value.processor.AutoValueBuilderProcessor
com.google.auto.value.processor.AutoValueProcessor
org.immutables.processor.ProxyProcessor 标准注释处理器规范位置
生成的源与模板源的关系 增强的生成类替换模板源 生成的源扩展了模板源 Lombok仅显示带有“ delombok”选项的生成源
访问生成的源 指定delombok选项 默认 默认 查看/控制生成的源代码
生成方法 equals(Object) , hashCode() , toString() , 构造 /生成器 , 访问器 , 设置器 equals(Object),hashCode(),toString(),构造/生成器,访问器 equals(Object) , hashCode() , toString() , 构造 /生成器 ,访问器, 设置器
不变程度 允许使用字段级@Set进行完全可变,但在需要不可变性时提供@Value 加强严格的不变性 “ 偏重于不变性 ”,但提供了类级别的@ Value.Modifiable AutoValue的意见最多,Lombok的意见最少
奖励功能 资源清理
不可变或可变
偷偷地抛出检查异常 对象同步锁 记录注释 更多 …
忠实于价值客体的概念
记录的最佳做法
样式定制
序列化 (包括JSON )
预先计算的哈希码 更多…

选择时的注意事项

Lombok,AutoValue和Immutables是类似的工具包,它们提供类似的好处,并且这三种方法中的任何一种都可以被广泛的应用程序成功使用。 但是,在选择使用哪个工具箱时,可以考虑它们之间的差异。

  • Lombok生成的类和模板具有相同的包和类名,而AutoValue和Immutables生成的类扩展了模板类并具有自己的类名(但具有相同的包)。
    • 希望编译的.class文件具有与模板类完全相同的包和名称的开发人员将首选Lombok。
  • AutoValue是这三个工具包中最自以为是的,而Lombok则是最不自以为是的。
    • 希望严格执行“值对象”特征的开发人员可能更喜欢AutoValue。
  • AutoValue和Immutables使用标准注释处理,而Lombok使用非标准注释处理方法。
    • 希望避免非标准依赖关系的开发人员将倾向于使用AutoValue或Immutables。
  • 这三个工具箱都支持某种程度的自定义,并且希望自定义生成的代码的开发人员可能希望选择允许他们以所需方式自定义生成的代码的工具箱。
    • Lombok提供了一种配置系统 ,该系统允许将生成的代码的多个方面调整为所需的约定。
  • JDK 1.6支持AutoValue和Lombok,但Immutables需要JDK 1.7。

结论

Lombok,AutoValue和Immutables有很多共同点,并且全部三个都可以用于从简单的模板文件生成值类。 但是,它们各自提供不同的优点和功能,这可能会导致它们中的任何一个相对于其他开发者都具有不同的吸引力,具体取决于开发者的个人情况。

翻译自: https://www.javacodegeeks.com/2016/06/lombok-autovalue-immutables.html

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

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

相关文章

用interrupt()中断Java线程

Javathread 最近在学习Java线程相关的东西,和大家分享一下,有错误之处欢迎大家指正. 假如我们有一个任务如下,交给一个Java线程来执行,如何才能保证调用interrupt()来中断它呢? Java代码 class ATask imple…

JAVA分代收集机制详解

Java堆中是JVM管理的最大一块内存空间。主要存放对象实例。在JAVA中堆被分为两块区域:新生代(young)、老年代(old)。堆大小新生代老年代;(新生代占堆空间的1/3、老年代占堆空间2/3)新…

高可用架构

转载于:https://www.cnblogs.com/138026310/p/9088341.html

压缩vmware中的ubuntu系统(虚拟机瘦身大法)

压缩vmware中的ubuntu系统&#xff08;虚拟机瘦身大法&#xff09; 前提:你的虚拟机大小 < 你放置虚拟机的磁盘的剩余空间 1.在Termial(终端)里 运行"sudo vmware-toolbox"(需要root权限) 2.选择“shrink”选项卡 3.选中“/”&#xff0c;点击“shrink”按钮 4.完…

认识jQuery

一、JavaScript库 把一些浏览器兼容性的代码或者需要常用的函数装在一个js文件里,封装了很多js代码的一个js文件就是一个库 二、jQuery 是一个JavaScript库&#xff0c;免费开源的&#xff0c;体积小&#xff0c;链式编程&#xff0c;隐式迭代&#xff0c;很多优点jQuery 的功能…

Axis2 WebService(配置、发布、调用)

from:http://www.lifeba.org/arch/java_axis2_webservice.html 准备工作 1、下载&#xff1a;axis2-1.5.4-bin.zip,axis2-1.5.4-war.zip 下载地址&#xff1a;http://axis.apache.org/axis2/java/core/ 2、环境变量设置 AXIS2_HOME E:\research\axis2-1.5.4-bin\axis2-1.5.4 J…

SmartPDA图片

转载于:https://www.cnblogs.com/xyyshishuaige/p/9098613.html

基于国家标准的 EndNote 输出样式模板

发表于 2013-05-26作者 Haoxian Zeng浏览 983 次from:http://cnzhx.net/blog/endnote-output-style-cnzhx/1EndNote 相当于一个数据库&#xff0c;将添加/导入的文献存档。需要引用文献的时候就从中选择一个插入到文档中&#xff0c;EndNote 会自动给你编号、在文档末尾建立相应…

工厂设计模式解决什么问题_使用工厂模式解决设计问题

工厂设计模式解决什么问题工厂设计模式是面向对象环境中最常用的模式之一。 再次来自“创意设计”模式类别&#xff0c;即有关对象创建的所有信息。 在某些情况下&#xff0c;对象的创建很复杂&#xff0c;可能需要某种程度的抽象&#xff0c;以便客户端代码不了解这些复杂性和…

shiro 认证思路

转载于:https://www.cnblogs.com/hwgok/p/9101232.html

Java 9对可选的补充

哇&#xff0c;人们对Java 9的Stream API增添了 真正的兴趣。 想要更多&#xff1f; 让我们看一下…… 可选的 可选::流 这不需要任何解释&#xff1a; Stream<T> stream();想到的第一个词是&#xff1a; 终于 &#xff01; 最后&#xff0c;我们可以轻松地从可选值流…

Matlab功率谱估计

(2012-03-16 12:22:15) 随机信号处理 * 随机变量分布特征量 均值mean 协方差矩阵cov 相关系数矩阵corrcoef [R, P] corrcoef(X)&#xff0c;P值用于检验相关性&#xff0c;越小越相关&#xff0c;0.05以下为显著相关。 * 相关函数估计 相关函数估计xcorr [c,lags] xcorr(…

primefaces_PrimeFaces在GlassFish 3.1.2.2上推动大气

primefacesPrimeFaces 3.4在三天前发布。 除了通常令人敬畏的新组件和更新组件外&#xff0c;它还包括新的PrimeFaces Push框架。 基于Atmosphere&#xff0c;这为您的应用程序提供了简单的推送机制。 这是在最新的GlassFish 3.1.2.2上配置和运行它的方法。 准备工作 像往常一…

相关的意义

第四章 相关系数 [内容导读]   本章的内容在课程中具有承上启下的重要作用。一方面&#xff0c;相关系数是反映与描述一组数据的概括性特征量数&#xff0c;只不过这里的数据是二元变量的观测数据。另一方面&#xff0c;对相关系数内容的理解与掌握&#xff0c;是建立在散点…

35

1 转载于:https://www.cnblogs.com/venicid/p/9116284.html

glassfish默认密码_在MySQL上使用含盐密码的GlassFish JDBC安全性

glassfish默认密码我在该博客上最成功的文章之一是有关在GlassFish上使用基于表单的身份验证设置JDBC安全领域的文章 。 对这篇文章的一些评论使我意识到&#xff0c;要真正使它安全&#xff0c;应该做的还很多。 开箱即用的安全性 图片&#xff1a; TheKenChan &#xff08; …

带有WildFly Swarm的远程JMS

我再次在博客上谈论WildFly群&#xff1f; 简短的版本是&#xff1a;我需要对远程JMS访问进行测试&#xff0c;并且拒绝设置复杂的功能&#xff08;如完整的应用程序服务器&#xff09;。 这个想法是要有一个简单的WildFly Swarm应用程序&#xff0c;该应用程序配置了队列和主题…

nosql怎么使用_使用NoSQL实施实体服务–第5部分:使用云提高自治性

nosql怎么使用在之前的文章中&#xff0c;我讨论了如何通过结合使用Java Web Services &#xff0c; Java EE和CouchDB NoSQL数据库为产品构建SOA“实体”服务。 在本系列的最后一篇文章中&#xff0c;我将利用我已经创建的一些技术资产&#xff0c;并使用一些流行的SOA模式实现…

串口MSComm控件五种不同校验方式对数据收发的影响

(2008-09-10 14:50:00) http://blog.sina.com.cn/s/blog_470eccc60100arq7.html串口MSComm控件有五种校验方式&#xff0c;分别是无校验&#xff08;None&#xff09;&#xff0c;奇校验&#xff08;Odd&#xff09;&#xff0c;偶校验&#xff08;Even&#xff09;&#xff0c…

利刃 MVVMLight 3:双向数据绑定

利刃 MVVMLight 3&#xff1a;双向数据绑定 原文:利刃 MVVMLight 3&#xff1a;双向数据绑定上篇我们已经了解了MVVM的框架结构和运行原理。这里我们来看一下伟大的双向数据绑定。说到双向绑定&#xff0c;大家比较熟悉的应该就是AngularJS了&#xff0c;几乎所有的AngularJS 系…