Lombok 通过提供简单的语法注解形式来帮助简化消除一些必须有但显得很臃肿的 java 代码。典型的是对于 POJO对象的简化(如自动帮我们生成Setter和Gett…
Lombok 通过提供简单的语法注解形式来帮助简化消除一些必须有但显得很臃肿的 java 代码。典型的是对于 POJO对象的简化(如自动帮我们生成Setter和Getter等),有了Lombok的加持,开发人员可以免去很多重复且臃肿的操作,极大地提高java代码的信噪比,因此我们必须尝试并应用起来!
方法一:直接在IDEA界面中配置
上述安装完成以后需要重启IDEA生效!
方法二:手动下载Lombok插件安装
有时由于网络原因,上面方法一这种方式安装失败,因此只能手动下载安装
IDE中设置完成以后需要在pom.xml中添加如下所示的lombok依赖才能使用
@Getter and @Setter
/ 自动为属性提供 Set和Get 方法@ToString
/ 该注解的作用是为类自动生成toString()方法@EqualsAndHashCode
/ 为对象字段自动生成hashCode和equals实现@AllArgsConstructor, @RequiredArgsConstructor and @NoArgsConstructor
/ 顾名思义,为类自动生成对应参数的constructor@Log, @Log4j, @Log4j2, @Slf4j, @XSlf4j, @CommonsLog, @JBossLog
/ 自动为类添加对应的log支持@Data
/ 自动为所有字段添加@ToString, @EqualsAndHashCode, @Getter,为非final字段添加@Setter,和@RequiredArgsConstructor,本质上相当于几个注解的综合效果@NonNull
/ 自动帮助我们避免空指针。作用在方法参数上的注解,用于自动生成空值参数检查@Cleanup
/ 自动帮我们调用close()方法。作用在局部变量上,在作用域结束时会自动调用close方法释放资源下文就Lombok中用的最为频繁的@Data
和@Log
注解进行代码实战!
官网关于@Data注解的解释如下:
All together now: A shortcut for @ToString, @EqualsAndHashCode, @Getter on all fields, @Setter on all non-final fields, and @RequiredArgsConstructor!
不难理解,其可以看成是多个Lombok注解的集成,因此使用很方便!
在IDEA中使用时,Lombok的注解会自动补全,如下图所示:
由下图我们可以看到IDEA依然可以自动为我们补全由Lombok自动生成的代码:
由于Lombok为我们自动生成了toString方法,因此对象的打印结果如下:
在我的文章 Spring Boot日志框架实践 一文中,我们使用Log4j2来作为日志对象,其写法如下:
若改用Lombok后,写法变得更加简洁,我们只需要引入对应的@Log注解即可完成log对象的生成:
怎么样,是不是一切都是那么地优雅!
作者更多的SpringBt实践文章在此: