@Data
介绍了以上的注解,再来介绍 @Data
就非常容易懂了,@Data
注解应用在类上,是@ToString
, @EqualsAndHashCode
, @Getter / @Setter
和 @RequiredArgsConstructor
合力的体现,如下图:
@Builder
函数式编程或者说流式的操作越来越流行,应用在大多数语言中,让程序更具更简介,可读性更高,编写更连贯,@Builder
就带来了这个功能,生成一系列的builder API,该注解也需要应用在类上,看下面的例子就会更加清晰明了。
编译后的Employee.class文件如下:
妈妈再也不用担心我 set 值那么麻烦了,流式操作搞定:
@Log
该注解需要应用到类上,在编写服务层,需要添加一些日志,以便定位问题,我们通常会定义一个静态常量Logger,然后应用到我们想日志的地方,现在一个注解就可以实现:
查看class文件,和我们预想的一样:
Log有很多变种,CommonLog,Log4j,Log4j2,Slf4j等,lombok依旧良好的通过变种注解做良好的支持:
我实际使用的是 @Slf4j
注解
val
熟悉 Javascript 的同学都知道,var 可以定义任何类型的变量,而在 java 的实现中我们需要指定具体变量的类型,而 val 让我们摆脱指定,编译之后就精准匹配上类型,默认是 final 类型,就像 java8 的函数式表达式,()->System.out.println(“hello lombok”); 就可以解析到Runnable函数式接口。
查看解析后的class文件:
@Cleanup
当我们对流进行操作,我们通常需要调用 close 方法来关闭或结束某资源,而 @Cleanup 注解可以帮助我们调用 close 方法,并且放到 try/finally 处理块中,如下图:
编译后的class文件如下,我们发现被try/finally包围处理,并调用了流的close方法
其实在 JDK1.7 之后就有了 try-with-resource
,不用我们显式的关闭流,这个请大家自行看吧
总结
Lombok的基本操作流程是这样的:
- 定义编译期的注解
- 利用JSR269 api(Pluggable Annotation Processing API )创建编译期的注解处理器
- 利用tools.jar的javac api处理AST(抽象语法树)
- 将功能注册进jar包
Lombok 当然还有很多注解,我推荐使用以上就足够了,这个工具是带来便利的,而不能被其捆绑,“弱水三千只取一瓢饮,代码千万需抓重点看”,Lombok 能让我更加专注有效代码排除意义微小的障眼代码(get,set等),另外Lombok生成的代码还能像使用工具类一样方便(@Builder)。
灵魂追问
- 为什么只有一个整体
@EqualsAndHashCode
注解?而不是@Equals
和@HashCode
?这涉及到一个规范哦
- 如果把三种构造器方式同时应用又加上了
@Builder
注解,会发生什么?
- 你的灯还亮着吗?