使用Lombok

我们发现,在以往编写项目时,尤其是在类进行类内部成员字段封装时,需要编写大量的get/set方法,这不仅使得我们类定义中充满了get和set方法,同时如果字段名称发生改变,又要挨个进行修改,甚至当字段变得很多时,构造方法的编写会非常麻烦!
通过使用Lombok(小辣椒)就可以解决这样的问题!
1-4 Lombok - 图1
我们来看看,使用原生方式和小辣椒方式编写类的区别,首先是传统方式:

  1. public class Student {
  2. private Integer sid;
  3. private String name;
  4. private String sex;
  5. public Student(Integer sid, String name, String sex) {
  6. this.sid = sid;
  7. this.name = name;
  8. this.sex = sex;
  9. }
  10. public Integer getSid() { //长!
  11. return sid;
  12. }
  13. public void setSid(Integer sid) { //到!
  14. this.sid = sid;
  15. }
  16. public String getName() { //爆!
  17. return name;
  18. }
  19. public void setName(String name) { //炸!
  20. this.name = name;
  21. }
  22. public String getSex() {
  23. return sex;
  24. }
  25. public void setSex(String sex) {
  26. this.sex = sex;
  27. }
  28. }

而使用Lombok之后:

@Getter
@Setter
@AllArgsConstructor
public class Student {
    private Integer sid;
    private String name;
    private String sex;
}

我们发现,使用Lombok之后,只需要添加几个注解,就能够解决掉我们之前长长的一串代码!

配置Lombok

  • 首先我们需要导入Lombok的jar依赖,和jdbc依赖是一样的,放在项目目录下直接导入就行了。可以在这里进行下载:https://projectlombok.org/download
  • 然后我们要安装一下Lombok插件,由于IDEA默认都安装了Lombok的插件,因此直接导入依赖后就可以使用了。
  • 重启IDEA

Lombok是一种插件化注解API,是通过添加注解来实现的,然后在javac进行编译的时候,进行处理。

Java的编译过程可以分成三个阶段:

1-4 Lombok - 图2

  1. 所有源文件会被解析成语法树。
  2. 调用注解处理器。如果注解处理器产生了新的源文件,新文件也要进行编译。
  3. 最后,语法树会被分析并转化成类文件。

实际上在上述的第二阶段,会执行lombok.core.AnnotationProcessor,它所做的工作就是我们上面所说的,修改语法树。

使用Lombok

我们通过实战来演示一下Lombok的实用注解:

  • 我们通过添加@Getter@Setter来为当前类的所有字段生成get/set方法,他们可以添加到类或是字段上,注意静态字段不会生成,final字段无法生成set方法。
    • 我们还可以使用@Accessors来控制生成Getter和Setter的样式。
  • 我们通过添加@ToString来为当前类生成预设的toString方法。
  • 我们可以通过添加@EqualsAndHashCode来快速生成比较和哈希值方法。
  • 我们可以通过添加@AllArgsConstructor@NoArgsConstructor来快速生成全参构造和无参构造。
  • 我们可以添加@RequiredArgsConstructor来快速生成参数只包含final或被标记为@NonNull的成员字段。
  • 使用@Data能代表@Setter@Getter@RequiredArgsConstructor@ToString@EqualsAndHashCode全部注解。
    • 一旦使用@Data就不建议此类有继承关系,因为equal方法可能不符合预期结果(尤其是仅比较子类属性)。
  • 使用@Value@Data类似,但是并不会生成setter并且成员属性都是final的。
  • 使用@SneakyThrows来自动生成try-catch代码块。
  • 使用@Cleanup作用与局部变量,在最后自动调用其close()方法(可以自由更换)
  • 使用@Builder来快速生成建造者模式。
    • 通过使用@Builder.Default来指定默认值。
    • 通过使用@Builder.ObtainVia来指定默认值的获取方式。