一、簡介
Lombok 是一個開源的 Java 庫,可以自動化生成 Java 類的 getter、setter、equals、hashCode 等常用方法,減少了編寫樣板式代碼的工作量,提高開發效率。Lombok.Data 是 Lombok 中的一個註解,可以自動在類上生成 getter、setter、equals、hashCode 和 toString 方法。
二、@Data 註解的使用
要使用 Lombok.Data 需要在 pom.xml 文件中添加以下依賴:
{@code
org.projectlombok
lombok
1.18.16
provided
}
在 Java 類上添加 @Data 註解即可自動生成 getter、setter、equals、hashCode 和 toString 方法。
{@code
import lombok.Data;
@Data
public class User {
private int id;
private String name;
}
}
以上代碼會自動生成以下方法:
{@code
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
User user = (User) o;
return id == user.id &&
Objects.equals(name, user.name);
}
@Override
public int hashCode() {
return Objects.hash(id, name);
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
}
三、@Data 註解的特點
1. 鏈式調用
通過在屬性上使用 @Setter 和 @Accessors 註解,可以實現鏈式調用。使用 @Setter(chain = true) 開啟鏈式調用,@Accessors(chain = true) 控制鏈式調用的相關行為。
{@code
import lombok.Data;
import lombok.experimental.Accessors;
@Data
@Accessors(chain = true)
public class User {
private int id;
private String name;
}
// 使用
User user = new User().setId(1).setName("Tom");
}
2. 默認構造函數
在類上添加 @Data 註解,就會默認生成一個無參構造函數。
{@code
@Data
public class User {
private int id;
private String name;
public User(){}
}
}
3. 全參構造函數
在類上添加 @AllArgsConstructor 註解,就會自動生成一個包含所有參數的構造函數。
{@code
@Data
@AllArgsConstructor
public class User {
private int id;
private String name;
}
}
4. 靜態方法
在類上添加 @Data(staticConstructor = “of”) 註解,就會自動生成一個以參數為輸入的靜態工廠方法。此方法的名稱可以在註解中指定。
{@code
@Data(staticConstructor = "of")
public class User {
private int id;
private String name;
}
// 使用
User user = User.of(1, "Tom");
}
四、@Data 註解的局限性
雖然 @Data 註解可以大大減少樣板代碼,但是也有它的局限性。下面是幾個 @Data 註解的局限性:
1. 不能控制生成方法的可見性
@Data 註解會將所有屬性的訪問級別設置為 public,不能控制生成方法的可見性。
{@code
@Data
public class User {
private int id;
private String name;
}
// 生成結果如下(getter 和 setter 方法都是 public 的):
public int getId() {...}
public void setId(int id) {...}
public String getName() {...}
public void setName(String name) {...}
}
2. 相同名稱的屬性會出現名稱衝突問題
如果有兩個屬性的名稱相同,@Data 註解會將它們的 getter 和 setter 方法的名稱都設置為相同的名稱,會出現名稱衝突問題。
{@code
@Data
public class User {
private int id;
private String name;
private String email;
}
// 生成結果如下(name 的 getter 和 setter 方法和 email 的 getter 和 setter 方法名字是相同的):
public String getName() {...}
public void setName(String name) {...}
public String getEmail() {...}
public void setEmail(String email) {...}
}
3. 不能自定義 equals 和 hashCode 方法的具體實現
@Data 註解生成的 equals 和 hashCode 方法是基於所有屬性的默認實現,不能自定義它們的具體實現。
五、總結
Lombok.Data 可以大大減少樣板代碼的編寫,提高開發效率。但是它也有它的局限性,需要根據具體情況進行選擇。在實際開發中,可以根據具體需要使用 Lombok 的其他註解來解決上述問題。例如 @Getter、@Setter、@ToString、@EqualsAndHashCode 等。
原創文章,作者:AZKDE,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/368138.html
微信掃一掃
支付寶掃一掃