Lombok注解@Getter @Setter详解

Lombok是一款Java库,通过注解自动生成getter、setter等方法,减少代码量,提高开发效率。本文介绍Lombok的安装、常用注解及工作原理,探讨其对代码维护的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.为什么强大

​ 项目中经常使用bean,entity等类,绝大部分数据类类中都需要get、set、toString、equals和hashCode方法,尽管IDE工具都会帮我们生成。但自动生成这些代码后,如果bean中的属性一旦有修改、删除或增加时,需要重新生成或删除get/set等方法,给代码维护增加负担。而使用了lombok之后,就不需要编写或生成setter或getter等方法了,而使用lombok注解的方式,在编译生成的字节码文件中就会存在setter/getter等方法,这样就大大减少了代码量,方便了代码的维护。

2.安装lombok插件(如果不安装会报错,提示没有get set方法)

使用前需要安装lombok插件

IDEA插件安装地址:https://jingyan.baidu.com/article/0a52e3f4e53ca1bf63ed725c.html

Eclipse插件地址:https://jingyan.baidu.com/article/b7001fe1aaa0c30e7282dd8a.html

3.maven依赖

在使用lombok插件的时候,还要进行添加lombok的Maven依赖,代码示例:

<dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.10</version>
</dependency>

4.常用注解

@Setter @Getter : 为相应属性添加get set方法

import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import java.util.Date;
 
@Setter
@Getter
@ToString
public class User {
    private Integer id;
 
    private String name;
 
    private Integer age;
 
    private String sex;
 
    private Date birthday;
 
}

@NonNull:该注解在属性或者构造器上,lombok会自动生成一个非空声明,用于校验参数,避免空指针

import lombok.NonNull;
 
public class NonNullExample extends Something {
  private String name;
  
  public NonNullExample(@NonNull Person person) {
    super("Hello");
    this.name = person.getName();
  }
}

@Cleanup:该注解能帮助我们自动调用close()方法,很大程度简化代码可读性

import lombok.Cleanup;
import java.io.*;
 
public class CleanupExample {
  public static void main(String[] args) throws IOException {
    @Cleanup InputStream in = new FileInputStream(args[0]);
    @Cleanup OutputStream out = new FileOutputStream(args[1]);
    byte[] b = new byte[10000];
    while (true) {
      int r = in.read(b);
      if (r == -1) break;
      out.write(b, 0, r);
    }
  }
}

@EqualsAndHashCode:默认情况下,会使用所有非静态(non-static)和非瞬态(non-transient)属性来生成equals和hasCode,也能通过exclude注解来排除一些属性。

import lombok.EqualsAndHashCode;
 
@EqualsAndHashCode(exclude={"id", "shape"})
public class EqualsAndHashCodeExample {
  private transient int transientVar = 10;
  private String name;
  private double score;
  private Shape shape = new Square(5, 10);
  private String[] tags;
  private int id;
  
  public String getName() {
    return this.name;
  }
  
  @EqualsAndHashCode(callSuper=true)
  public static class Square extends Shape {
    private final int width, height;
    
    public Square(int width, int height) {
      this.width = width;
      this.height = height;
    }
  }
}

@ToString:类使用@ToString注解,Lombok会生成一个toString()方法,默认情况下,会输出类名、所有属性(会按照属性定义顺序),用逗号来分割。

代替效果为:

@Override public String toString() {
      return "Square(
      super=" + super.toString() + ", 
      width=" + this.width + ", 
      height=" + this.height + 
      ")";
    }
}

@Data:注解在类上,会为类的所有属性自动生成setter/getter、equals、canEqual、hashCode、toString方法,如为final属性,则不会为该属性生成setter方法。这个注解可是说是非常强大。

5.lombok工作原理

Lombok本质上就是一个实现了“JSR 269 API”的程序。在使用javac的过程中,它产生作用的具体流程如下:

  1. javac对源代码进行分析,生成了一棵抽象语法树(AST)
  2. 运行过程中调用实现了“JSR 269 API”的Lombok程序
  3. 此时Lombok就对第一步骤得到的AST进行处理,找到@Data注解所在类对应的语法树(AST),然后修改该语法树(AST),增加getter和setter方法定义的相应树节点
  4. javac使用修改后的抽象语法树(AST)生成字节码文件,即给class增加新的节点(代码块)

6.总结

Lombok的使用通过注解的方式减少了getter,setter的手动增加减少了代码量,增加开发效率,特别是在改动属性名字时候维护起来也特别容易。但是同时它也减少了代码的可阅读性降低了源码的舒适度。

转载于:https://www.cnblogs.com/shundong106/p/10995748.html

<think>首先,用户的问题是关于Java Lombok注解的用法,具体包括@Getter@Setter、@NoArgsConstructor、@AllArgsConstructor和@ToString。我需要根据系统级指令来构建回答。 系统级指令关键点: - 所有行内数学表达式必须使用$...$格式,但在这个上下文中,可能没有数学表达式,所以我可以忽略。 - 独立公式用$$...$$,但同样,这里可能不适用。 - LaTeX语法正确:确保任何数学内容正确格式化。 - 使用中文回答:整个回答必须是中文。 - 生成相关问题:在回答结束时,生成相关问题。 - 引用段落末尾添加引用标识:引用提供的引用内容时,在末尾加[^1]、[^2]等。 - 回答结构清晰:帮助用户逐步解决问题。 - 参考站内引用:引用中提供了关于Lombok注解的信息,我需要整合这些。 用户意图:从引用中,用户想了解Lombok注解的功能和用法。引用[^1]、[^2]、[^3]、[^4]详细描述了这些注解。 回答结构: 1. **引言**:简要介绍Lombok及其作用。 2. **逐步解释每个注解**: - @Getter@Setter - @ToString - @NoArgsConstructor - @AllArgsConstructor 3. **示例代码**:提供Java代码示例来展示用法。 4. **总结**:概述优点。 5. **生成相关问题**:在结尾添加相关问题。 引用整合: - 引用[^1]:解释@Data和@AllArgsConstructor。 - 引用[^2]:示例使用@AllArgsConstructor、@RequiredArgsConstructor、@NoArgsConstructor。 - 引用[^3]:详细说明@Data、@Getter@Setter。 - 引用[^4]:全面介绍Lombok注解,包括@Getter@Setter、@ToString、@NoArgsConstructor、@AllArgsConstructor等。 在回答中,当引用这些信息时,在段落末尾添加[^1]、[^2]等。例如,如果提到@Data的功能,加[^3]。 确保回答真实可靠:基于提供的引用内容,因为用户指定了这些引用。 代码示例:使用代码块展示注解的实际应用。系统指令要求在代码块中使用正确格式,如Python示例。 语言:全部用中文。 生成相关问题:在结尾,添加3-5个相关问题,如"如何避免Lombok的常见陷阱?"或"Lombok与手动编写代码的优缺点?" 最终回答框架: - 开头:介绍Lombok。 - 主体:分小节解释每个注解,包括功能、用法和示例代码。 - 结尾:总结和添加相关问题。</think>### Java Lombok 注解用法详解 Lombok 是一个流行的 Java 库,通过注解自动生成样板代码(如 gettersetter、构造方法等),简化开发并减少冗余代码。以下我将逐步解释您提到的注解@Getter@Setter、@NoArgsConstructor、@AllArgsConstructor、@ToString)的功能和用法,确保回答基于可靠引用。每个注解都配有代码示例,帮助您快速上手。 #### 1. **@Getter@Setter 注解** - **功能**:自动为类的字段生成 gettersetter 方法。您可以在类级别或字段级别应用这些注解。如果应用于类,所有非静态字段都会生成对应方法;如果应用于单个字段,则仅针对该字段生效[^3][^4]。 - **用法**: - 类级别:为所有字段生成方法。 - 字段级别:为特定字段生成方法。 - **注意事项**:final 字段不会生成 setter 方法,因为其值不可修改[^3]。 - **示例代码**: ```java import lombok.Getter; import lombok.Setter; @Getter // 为所有字段生成 getter @Setter // 为所有字段生成 setter public class User { private String name; // 自动生成 getName() 和 setName() private final int age; // 只生成 getAge(),因为 final 字段无 setter private String email; } ``` 编译后,Lombok 会自动添加 `getName()`、`setName()`、`getAge()` 等方法。 #### 2. **@ToString 注解** - **功能**:自动生成 `toString()` 方法,输出类所有字段的值。默认包含所有非静态字段,但您可以通过 `exclude` 参数排除特定字段[^4]。 - **用法**:应用于类级别。适合调试时快速查看对象状态。 - **示例代码**: ```java import lombok.ToString; @ToString(exclude = "password") // 排除 password 字段 public class Account { private String username; private String password; // 不会被包含在 toString() private double balance; } ``` 实例化 `Account` 后,调用 `toString()` 会返回类似 `Account(username=admin, balance=100.0)` 的字符串。 #### 3. **@NoArgsConstructor 注解** - **功能**:生成无参构造方法(默认构造器)。如果类中有 final 字段,需使用 `force = true` 参数强制初始化(例如设置为默认值)[^2][^4]。 - **用法**:应用于类级别。常用于框架(如 Spring)需要默认构造器的场景。 - **示例代码**: ```java import lombok.NoArgsConstructor; @NoArgsConstructor(force = true) // 强制生成无参构造器,处理 final 字段 public class Product { private final String id; // force=true 会初始化为 null private String name; } ``` 编译后,类会包含 `Product() {}` 构造器。 #### 4. **@AllArgsConstructor 注解** - **功能**:生成包含所有字段的构造方法,按字段声明顺序参数化。简化对象初始化[^1][^4]。 - **用法**:应用于类级别。与 `@NoArgsConstructor` 结合使用更灵活。 - **示例代码**: ```java import lombok.AllArgsConstructor; @AllArgsConstructor // 生成包含所有字段的构造器 public class Order { private String orderId; private double amount; } ``` 使用时可直接 `new Order("123", 99.99)`,无需手动编写构造器。 #### 总结与最佳实践 - **优点**:Lombok 减少样板代码,提高开发效率。例如,`@Data` 注解组合了 `@Getter`、`@Setter`、`@ToString`、`@EqualsAndHashCode` 等功能[^3][^4]。 - **注意事项**: - 确保 IDE 安装了 Lombok 插件(如 IntelliJ 的 Lombok Plugin),否则编译时可能报错。 - 避免在继承层次复杂的类中过度使用,以免生成的方法冲突。 - 引用说明:本文内容基于 Lombok 官方文档和社区实践,确保可靠性[^1][^2][^3][^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值