Lombok其实和Spring Boot关系不太大,只是这个工具太好用了,这里也整理记录一下。 Lombok是一个Java库可以与Java IDE(ItelliJ IDEA、Eclipse)和构建工具(Gradle、Maven)集成,帮助开发人员消除臃肿的Java代码,尤其是对于Java POJO类,使用Lombok后将不再需要我们去编写getter、setter、equals、hashcode等方案,Lombok通过注解实现这一目标。

Lombok的安装和配置

Lombok是一个Java库需要与Java IDE(ItelliJ IDEA、Eclipse)和构建工具(Gradle、Maven)集成。 Lombok的安装和配置实际上就是与IDE和构建工具的集成过程。

与Gradle集成

先来看与构建工具的集成,这里以gradle为例:

 1plugins {
 2	id 'org.springframework.boot' version '2.1.3.RELEASE'
 3	id 'java'
 4}
 5
 6apply plugin: 'io.spring.dependency-management'
 7
 8group = 'spring-boot-guides'
 9version = '0.0.1-SNAPSHOT'
10sourceCompatibility = '1.8'
11
12configurations {
13	compileOnly {
14		extendsFrom annotationProcessor
15	}
16}
17
18repositories {
19	mavenCentral()
20}
21
22dependencies {
23	implementation 'org.springframework.boot:spring-boot-starter'
24	compileOnly 'org.projectlombok:lombok'
25	annotationProcessor 'org.projectlombok:lombok'
26	testImplementation 'org.springframework.boot:spring-boot-starter-test'
27}

annotationProcessor 'org.projectlombok:lombok'是为Gradle引入lombok编译时注解处理器的依赖,Gradle在编译时会使用注解处理器。这块具体的代码可以查看lombok.launch包中代码如lombok.launch.AnnotationProcessorHider.AnnotationProcessor

compileOnly 'org.projectlombok:lombok'是为开发人员引入编译依赖,引入这个依赖后,在编写代码时就可以使用lombok的注解了,例如:

 1package springbootguides.lombokdemo.entity;
 2
 3import lombok.AllArgsConstructor;
 4import lombok.Builder;
 5import lombok.Data;
 6import lombok.NoArgsConstructor;
 7
 8@Data
 9@Builder
10@NoArgsConstructor
11@AllArgsConstructor
12public class User {
13    private int id;
14    private String name;
15}

@Data @Builder...等这些注解只有在编译时才会用到,所以这里使用compileOnly更为准确一些。

编写下面的测试代码:

 1package springbootguides.lombokdemo;
 2
 3import org.springframework.boot.CommandLineRunner;
 4import org.springframework.boot.SpringApplication;
 5import org.springframework.boot.autoconfigure.SpringBootApplication;
 6import springbootguides.lombokdemo.entity.User;
 7
 8@SpringBootApplication
 9public class LombokDemoApplication implements CommandLineRunner {
10
11	public static void main(String[] args) {
12		SpringApplication.run(LombakDemoApplication.class, args);
13	}
14
15	@Override
16	public void run(String... args) throws Exception {
17		User user = new User();
18		user.setId(1);
19		user.setName("Jane");
20		User user2 = User.builder().id(2).name("Frank").build();
21		System.out.println(user.toString());
22		System.out.println(user2.toString());
23	}
24}

运行gradle compileJava,可以看到在User类中并没有编写getter、setter、builder等方法,测试类中使用了它们且可以编译通过。

与Intellij IDEA集成

在lombok与gradle集成之后,通过修改Idea的配置: Settings -> Build,Execution,Deployment -> Build Tools -> Gradle -> Runner: 勾选Delegate IDE build/run actions to gradle,并选择Run tests using Gradle Test Runner。 此时运行IDEA的Build或Run功能,都会委托给gradle,对于使用了lombok的项目也是可以编译和运行的。

但美中不足的地方是lombok,此时项目中lombok为我们生成的地方在IDEA中显示有红色,这是因为IDEA还不认识,只是Gradle认识它们。 因此还需要配置lombok与IDEA集成,只需要给IDEA安装lombok-plugin即可。

注:Delegate IDE build/run actions to gradle不是必须的,但是对于项目构建中使用gradle做了深度的定制的还是有必要的。例如我们的grpc java服务项目使用了protobuf-gradle-plugin将protobuf IDL文件生成java代码,此时需要将IDEA的构建和运行委托给gradle,具体查看https://github.com/google/protobuf-gradle-plugin

Lombok的使用

关于lombok的使用快速读一遍它的官方文档即可:

另外lombok官网上还提供了一个4分钟的演示视频看一遍差不多就够了。

Lombok的原理

Lombok主要是将编译期定义的注解,利用JSR269(Pluggable Annotation Processing API)的编译器注解处理器,在javac编译阶段对这些注解进行预处理后生成可用的Class文件。

参考