目录
一、流程1、安装Lombok插件2、启用注解处理器二、原理三、原因四、解决办法一、流程
1、安装Lombok插件
(2020.0.4之后版本的IDEA已内置Lombok,老版本的请自行下载插件)
2、启用注解处理器
打开setting -> enable annotation processor (启用注解处理器)
OK 完事~ 可以使用了 送上常用四件套:
@Data //生成Getter 、Setter 、ToString 、ToString 、EqualsAndHashCode @AllArgsConstructor //全参构造 @NoArgsConstructor //无参构造 @SuperBuilder //构建器,可以链式构建对象
可以自行在classes里看生成的代码:
正常来说到这就结束了,但是。。。在Lombok和MapStruct一起使用时就会有一些冲突
说明一下:
Lombok和MapStruct都是用来简化Java代码的组件,它可以通过AnnotationProcessor在编译时自动生成代码,简化了我们日常开发。
同时,由于是编译时生成的class文件,从安全性和性能角度考虑也会比运行时的工具好很多,例如BeanUtil.copy()
二、原理
javac对源代码进行分析,生成一棵抽象语法树(AST)运行过程中调用实现了"JSR 269 API"的lombok程序此时lombok就对第一步骤得到的AST进行处理,找到@Data注解所在类对应的语法树(AST),然后修改该语法树(AST),增加getter和setter方法定义的相应树节点javac使用修改后的抽象语法树(AST)生成字节码文件自从Java 6起,javac就支持“JSR 269 Pluggable Annotation Processing API”规范,只要程序实现了该API,就能在javac运行的时候得到调用。 lombok本质上就是这样的一个实现了"JSR 269 API"的程序。在使用javac的过程中,它产生作用的具体流程如下:
三、原因
因为他们他们都是编译时通过AnnotationProcessor生成的class文件,然后MapStruct会用到对象中的get、set方法,然后get、set方法又需要lombok来生成。所以我们需要空着这两者工作顺序。
四、解决办法
lombok 1.18.16之前,添加path
lombok 1.18.16之后,添加path,必须使用 lombok-mapstruct-binding 插件。
本着用新不用旧的想法我选了第二种
到此这篇关于Lombok和MapStruct整合详情的文章就介绍到这了,更多相关Lombok和MapStruct内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭