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 的注解介紹,感謝其他大牛的帖子。
