@Data
注解是 Lombok 提供的一个非常实用的注解。它可以自动为类生成常用的功能,减少样板代码的编写。具体来说,使用 @Data
注解会自动为你的类生成以下元素:
1. Getter 和 Setter 方法
对于类中的每个字段,Lombok 会自动生成对应的 getter 和 setter 方法。这意味着你无需手动编写这些方法,从而简化了代码。
2. toString 方法
@Data
自动生成 toString()
方法,这样你可以方便地打印对象的字符串表示,包含所有字段的信息。
3. equals 和 hashCode 方法
Lombok 会生成 equals()
和 hashCode()
方法,以便于对象之间的比较和集合中元素的唯一性检查。这些方法会基于对象的字段值进行比较。
4. 构造器
@Data
会生成一个全局的构造器(即包含所有字段的构造方法),允许你以一种简洁的方式创建对象。
示例代码
以下是一个示例,展示了 @Data
注解的用法:
import lombok.Data;
@Data
public class User {
private String name;
private int age;
}
自动生成的方法
使用 @Data
注解后,Lombok 会自动生成的代码大致如下:
public class User {
private String name;
private int age;
// Getter 和 Setter 方法
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
// toString 方法
@Override
public String toString() {
return "User{name='" + name + "', age=" + age + "}";
}
// equals 和 hashCode 方法
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (!(o instanceof User)) return false;
User user = (User) o;
return age == user.age && Objects.equals(name, user.name);
}
@Override
public int hashCode() {
return Objects.hash(name, age);
}
// 全参数构造器
public User(String name, int age) {
this.name = name;
this.age = age;
}
}
总结
@Data
注解是一个强大的工具,可用来简化类的设计,减少样板代码。- 它自动生成 getter、setter、
toString
、equals
和hashCode
方法,提供全参数的构造器。 - 适用于需要简单 Java Bean 类的场景,尤其是在涉及到数据封装时。
使用 Lombok 的 @Data
注解后,可以使你的代码更加简洁和易读,提高开发效率。