lombok 插件怎么使用这里就不多说了(请自行百度)。
@Data 注解首先是省略了实体类变量的set/get。这个是大家都能理解的。此处不多说了。
import lombok.Data; import lombok.EqualsAndHashCode; import lombok.experimental.Accessors; import java.io.Serializable; @Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) @TableName("user") public class User implements Serializable { // 代码题省略 }
@EqualsAndHashCode
原文中提到的大致有以下几点:
1. 此注解会生成equals(Object other)
和 hashCode()
方法。
2. 它默认使用非静态,非瞬态的属性
3. 可通过参数exclude
排除一些属性
4. 可通过参数of
指定仅使用哪些属性
5. 它默认仅使用该类中定义的属性且不调用父类的方法
6. 可通过callSuper=true
解决上一点问题。让其生成的方法中调用父类的方法。
另:@Data
相当于 @Getter @Setter @RequiredArgsConstructor @ToString @EqualsAndHashCode
这5个注解的合集。
通过官方文档,可以得知,当使用 @Data
注解时,则有了 @EqualsAndHashCode
注解,那么就会在此类中存在equals(Object other)
和 hashCode()
方法,且不会使用父类的属性,这就导致了可能的问题。
比如,有多个类有相同的部分属性,把它们定义到父类中,恰好id(数据库主键)也在父类中,那么就会存在部分对象在比较时,它们并不相等,却因为lombok自动生成的equals(Object other)
和 hashCode()
方法判定为相等,从而导致出错。
修复此问题的方法很简单:
1. 使用@Getter @Setter @ToString
代替@Data
并且自定义equals(Object other)
和 hashCode()
方法,比如有些类只需要判断主键id是否相等即足矣。
2. 或者使用在使用@Data
时同时加上@EqualsAndHashCode(callSuper=true)
注解。
@Accessors
Accessor的中文含义是存取器,@Accessors用于配置getter和setter方法的生成结果,下面介绍三个属性
fluent
fluent 的中文含义是流畅的,设置为true,则getter和setter方法的方法名都是基础属性名,且setter方法返回当前对象。如下
@Data @Accessors(fluent = true) public class User { private Long id; private String name; // 生成的getter和setter方法如下,方法体略 public Long id() {} public User id(Long id) {} public String name() {} public User name(String name) {} }
chain
chain的中文含义是链式的,设置为true,则setter方法返回当前对象。如下
@Data @Accessors(chain = true) public class User { private Long id; private String name; // 生成的setter方法如下,方法体略 public User setId(Long id) {} public User setName(String name) {} }
prefix
prefix的中文含义是前缀,用于生成getter和setter方法的字段名会忽视指定前缀(遵守驼峰命名)。如下
@Data @Accessors(prefix = "p") class User { private Long pId; private String pName; // 生成的getter和setter方法如下,方法体略 public Long getId() {} public void setId(Long id) {} public String getName() {} public void setName(String name) {} }
以上是对于 lombok 的注解介绍,感谢其他大牛的帖子。