Java lombok 使用教程

简介

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;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容