头图

简介

LombokJava 的一个 编译器插件,用于简化 Java 中常见样板代码(如 getter/setter、构造函数、toStringequals/hashCode 等)的编写,提高开发效率。

Lombok 安装与配置

Maven 依赖:

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

IDEA 插件支持:

  • 安装插件:Lombok Plugin
  • 启用注解处理:

    • Preferences → Build, Execution, Deployment → Compiler → Annotation Processors → ✅ Enable

常用注解

@Getter / @Setter

作用:自动生成字段的 gettersetter 方法。

@Getter
@Setter
public class User {
    private String name;
    private int age;
}

@ToString

作用:生成 toString() 方法。

参数:exclude(排除字段)、includeFieldNames(是否包含字段名)。

@ToString
public class User {
    private String name;
    private int age;
}

@EqualsAndHashCode

作用:生成 equals()hashCode() 方法。

参数:exclude(排除字段)、callSuper(是否包含父类字段)。

@EqualsAndHashCode
public class User {
    private String name;
    private int age;
}

@NoArgsConstructor / @AllArgsConstructor / @RequiredArgsConstructor

  • @NoArgsConstructor:无参构造函数;
  • @AllArgsConstructor:全参数构造函数;
  • @RequiredArgsConstructor:包含 final 字段和带 @NonNull 字段的构造函数,自动注入依赖
@NoArgsConstructor
@AllArgsConstructor
@RequiredArgsConstructor
public class User {
    private String name;
    private final int age;
}

@Data

相当于 @Getter + @Setter + @ToString + @EqualsAndHashCode + @RequiredArgsConstructor

@Data
public class User {
    private String name;
    private int age;
}

@Builder

构建者模式(Builder Pattern),支持链式构建对象。

@Builder
public class User {
    private String name;
    private int age;
}

// 使用方式:
User user = User.builder()
                .name("Tom")
                .age(25)
                .build();

@Value

用于不可变对象,相当于 @Data + final + private + 构造函数。

将类标记为不可变(所有字段自动生成 finalgetter,无 setter)。

@Value
public class User {
    String name;
    int age;
}

@SneakyThrows

用于忽略受检异,不需写 try-catchthrows

@SneakyThrows
public void test() {
    throw new IOException("Error");
}

@Slf4j

自动生成日志对象 log,用于日志打印。

为类自动生成 private static final Logger log = LoggerFactory.getLogger(...);

还有其他日志注解如 @Log4j2, @CommonsLog, @JBossLog 等。

@Slf4j
public class Demo {
    public void test() {
        log.info("This is a log");
    }
}

@Cleanup

自动关闭资源,相当于 try-with-resources

import lombok.Cleanup;

public class Example {
    public void readFile() throws IOException {
        @Cleanup InputStream in = new FileInputStream("file.txt");
        // use the input stream
    }
}

@Accessors

  • 配置 Getter/Setter 的生成规则

    • chain=true:Setter 返回当前对象,支持链式调用(user.setName("A").setAge(20))
    • fluent=true:生成无前缀的方法(如 user.name() 代替 user.getName()

@NonNull

自动生成空值检查逻辑

编译后自动抛出 NullPointerException 如果 name 为 null。

public void setName(@NonNull String name) {
    this.name = name;
}

唐青枫
25 声望4 粉丝