Lombok 使用指南

Lombok 是一个 Java 库,能自动插入编辑器和构建工具中,简化 Java 开发。
通过添加注解的方式,不需要为类编写 getter 或 equals 等方法,同时可以自动化日志变量。

简而言之:Lombok 能以简单的注解形式来简化 Java 代码,提高开发人员的开发效率。

官网链接:https://projectlombok.org/

以前的 Java 项目中,充斥着太多不友好的代码:POJO 的 getter / setter / toString;异常处理;I/O 流的关闭操作等等,这些样板代码既没有技术含量,又影响着代码的美观,Lombok 应运而生。对于 Lombok 的使用,也存在着不少争论。但是,IDEA 2020 最后一个发布版本已经内置了 Lombok 插件,并且 SpringBoot 2.1.x 之后的版本也在 Starter 中内置了 Lombok 依赖。

快速使用

1)在你的 Spring Boot 项目的中添加依赖配置:

<dependency>
  <groupId>org.projectlombok</groupId>
  <artifactId>lombok</artifactId>
  <scope>provided</scope>
</dependency>

2)常用注解说明:

注解说明
@Setter注解在类或字段,注解在类时为所有字段生成setter方法,注解在字段上时只为该字段生成setter方法。
@Getter注解在类或字段,注解在类时为所有字段生成getter方法,注解在字段上时只为该字段生成getter方法。
@ToString注解在类,生成toString方法。
@EqualsAndHashCode注解在类,生成hashCode和equals方法。
@NoArgsConstructor注解在类,生成无参的构造方法。
@RequiredArgsConstructor注解在类,为类中需要特殊处理的字段生成构造方法,比如final和被 @NonNull 注解的字段。
@AllArgsConstructor注解在类,生成包含类中所有字段的构造方法。
@NonNull注解在字段或方法,非空校验,抛出NullPointerException的异常。
@Data注解在类,等价于@Getter @Setter @RequiredArgsConstructor @ToString @EqualsAndHashCode
@SneakyThrows注解在方法,抛出异常(慎用)。
@Slf4j注解在类,生成log变量,严格意义来说是常量。等价于:
private static final Logger log=LoggerFactory.getLogger(UserController.class);
@UtilityClass注解在类,声明为工具类。
@Builder注解在类,No-hassle fancy-pants APIs for object creation!
@Synchronized注解在方法,声明同步方法。
@With注解在类或字段,声明作用域。

安装插件

在 IntelliJ IDEA 或者 Eclipse 中使用 Lombok 需要安装 Lombok Plugin。

因此,Lombok 也存在一定风险,在一些开发工具中没有 Project Lombok 支持选择。
IDE 和 JDK 升级也存在破裂的风险,以及围绕项目的目标和实施存在争议。

  • Eclipse: https://projectlombok.org/setup/eclipse
  • IntelliJ IDEA: https://projectlombok.org/setup/intellij
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值