@Data 是 Lombok 中的一个注解
代码语言:javascript复制<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.22</version>
</dependency>
它可以自动生成以下代码:
- 所有字段的 get 和 set 方法。
- toString() 方法,用于将对象转换成字符串形式,便于日志输出和调试。
- hashCode() 方法,用于计算对象的哈希值。
- equals() 方法,用于判断两个对象是否相等。
- 会生成一个无参构造方法
如果希望生成所有参数和指定参数的构造方法,可以使用 @AllArgsConstructor
或@RequiredArgsConstructor
等其他 Lombok 注解。需要注意的是,如果在实体类中手动编写了一个带参数的构造方法,使用 @Data 注解会覆盖掉手动编写的构造方法。
@RequiredArgsConstructor
也是Lombok
的一个注解,简化了我们对@Autowired
书写,我们在写Controller层或者Service层的时候,总是需要注入很多mapper接口或者service接口,如果每个接口都写上@Autowired,这样看起来就会很繁琐,@RequiredArgsConstructor注解可以代替@Autowired注解。
注意点
- 声明的变量必须加上final修饰
- 基于构造方法为属性赋值,容器通过调用类的构造方法将其进行依赖注入
@AllArgsConstructor和@RequiredArgsConstructor区别
- @AllArgsConstructor 生成一个包含所有字段的构造方法,如果使用了@Value注入,@Value注入会失效,因为@Value注解是通过对象的set方法赋值的,构造方法的执行还在set方法之前,所以在构造方法中使用,变量为null。
@RequiredArgsConstructor会将类的每一个final字段或者non-null字段生成一个构造方法
总结:
@AllArgsConstructor和@RequiredArgsConstructor都可以用来替代@Autowired写法,区别在于@RequiredArgsConstructor必须要有final修饰,如果有@Value注解,@RequiredArgsConstructor修饰可以成功注入,@AllArgsConstructor修饰会注入失败。