六,Spring Boot 容器中 Lombok 外掛的詳細使用,簡化配置,提高開發效率
@
- 六,Spring Boot 容器中 Lombok 外掛的詳細使用,簡化配置,提高開發效率
- 1. Lombok 介紹
- 2. Lombok 常用註解
- 2.1 @ToString
- 2.2 @Setter
- 2.3 @Data
- 2.4 @AllArgsConstructor
- 2.5 @NoArgsConstructor
- 3. 在 idea 中 安裝 lombok外掛
- 4. 總結:
- 6. 最後:
1. Lombok 介紹
Lombok 作用:
- 簡化 Java Bean開發,可以使用 Lombok 的註解讓程式碼更加簡潔。
- Java專案中,很多沒有技術含量但又必須存在的程式碼;比如:Pojo 的 getter/setter/toString ;異常處理:I/O流的關閉操作等等。
- Java專案中,很多沒有技術含量但又必須存在的程式碼:比如:這些程式碼既沒有技術含量,又影響著程式碼的美觀,Lombok 應運而生。
Spring Boot 和 IDEA 官方支援
- IDEA 2020已經內建了 Lombok外掛
- Spring Boot 2.1.x之後的版本也在 Stater中內建了 Lombok 依賴
2. Lombok 常用註解
@Data:註解在類上,提供類所有屬性的getting和setting方法,此外還提供了equals,canEqual,hashCode,toString方法
@Setter: 註解在屬性上,為屬性提供 setting 方法,註解在類上,則為類中的所有屬性提供 set()方法。
@Getter: 註解在屬性上,為屬性提供 getting 方法註解在類上,則為類中的所有屬性提供 get()方法。
@Log4j:註解在類上:為類提供了一個屬性名為: log 的 log4j的日誌物件
@NoArgsConstructor: 註解在類上,為類提供一個無參的構造方法,(一定會提供)
@AllArgsConstructor: 註解在類上,為類提供一個全參的構造方法
@Cleanup: 可以關閉流
@Builder: 被註解的類加個構造者模式
@Synchronized: 加同步鎖
@SneakyThrows: 等同於try/catcher捕獲異常
@NonNull:如果給引數加個這個註解,引數為null會丟擲空指標異常
@Value: 註解和@Value類似,區別在於它會把所有成員變數預設定義為 private final 修飾,並且不會生產set()方法
下面我們測試,使用幾個,在開發中比較常用的註解 。
首先想要使用上 Lombok 需要匯入相關 jar
依賴,也可以不用特別匯入,直接使用 Spring Boot 自帶內建的即可。
<!-- 引入 lombok ,使用版本仲裁-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.rainbowsea</groupId>
<artifactId>springboot_lombok</artifactId>
<version>1.0-SNAPSHOT</version>
<!-- 匯入SpringBoot 父工程-規定寫法-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.3</version>
</parent>
<dependencies>
<!-- 匯入web專案場景啟動器:會自動匯入和web開發相關的jar包所有依賴【庫/jar】-->
<!-- 後面還會在說明spring-boot-starter-web 到底引入哪些相關依賴-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 引入 lombok ,使用版本仲裁-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
</project>
2.1 @ToString
@ToString: // 在編譯時,生成 toString,注意:預設情況下,會生成一個無參構造器。
package com.rainbowsea.springboot.bean;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.ToString;
@ToString // 在編譯時,生成 toString,注意:預設情況下,會生成一個無參構造器
public class Furn {
private Integer id = 100;
private String name = "張三";
private Double price = 999.0;
}
使用 lombok 註解簡化程式碼,可以透過 idea 自帶的反編譯功能 target,看Furn.class的原始碼,就
可以看到生成的完整程式碼。
如果目錄當中沒有 target 目錄顯示,可以進行如下操作:
2.2 @Setter
@Setter 註解: 註解在屬性上,為屬性提供 setting 方法,註解在類上,則為類中的所有屬性提供 set()方法。
首先,我們先註解使用在屬性上。
package com.rainbowsea.springboot.bean;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.ToString;
public class Furn {
@Setter // 註解在屬性上,編譯生成一個,該屬性的 set()方法:預設情況下,會生成一個無參構造器
private Integer id = 100;
private String name = "張三";
private Double price = 999.0;
}
新增到類上,為類中所有的屬性都新增,set() 方法。
2.3 @Data
@Data :註解在類上,提供類所有屬性的getting和setting方法,此外還提供 equals,canEqual,hashCode,toString方法, @RequiredArgsConstructor
特別說明: @Data 中的 @RequiredArgsConstructor
在我們寫controller 或是 Service層的時候,需要注入很多的 mapper介面或者另外的service介面,這時候就會寫很多
的@Autowired註解,程式碼看起來很亂。Lombok 提供了一個註解:
@RequiredArgsConstructor(onConstructor=@_(@AutoWired))
寫在類上可以代替@Autowired註解,需要注意的時在注入時,需要用final定義,或者使用 @notnull註解
package com.rainbowsea.springboot.bean;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.ToString;
@Data// 註解等價使用了,如下註解: @Getter,@Setter,@RequiredArgsConstructor @ToString,@EqualsAndHas
public class Furn {
private Integer id = 100;
private String name = "張三";
private Double price = 999.0;
}
2.4 @AllArgsConstructor
@AllArgsConstructor:在編譯時,會生成全引數構造器
package com.rainbowsea.springboot.bean;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.ToString;
@AllArgsConstructor // 在編譯時,會生成全引數構造器
public class Furn {
private Integer id = 100;
private String name = "張三";
private Double price = 999.0;
}
注意:這裡:我們會發現一點,就是有全引數構造器,但是,卻沒有生成一個預設的“無引數構造器”
2.5 @NoArgsConstructor
@NoArgsConstructor: 在編譯時,會生成無參構造器(一定會生成),不會受到其它的
package com.rainbowsea.springboot.bean;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import lombok.ToString;
@NoArgsConstructor //在編譯時,會生成無參構造器(一定會生成),不會受到其它的
public class Furn {
private Integer id = 100;
private String name = "張三";
private Double price = 999.0;
}
特別說明:
特別說明,雖然上面的@Data,@ToString註解等等,預設情況下都會生成一個無參構造器,但是當你使用了多個註解的時候,可能會覆蓋掉無參構造器。 但是當我們有其它多個構造器生成時,你如果你希望仍然有無參構造器就需要使用 @NoArgsConstructor 註解了,因為 @NoArgsConstructor是一定會生成一個無參構造器的(無參構造器很重要,因為框架的使用是涉及到反射機制的,而反射機制,需要一個無參構造器,否則你就無法進行反射獲取 bean物件,框架也就無法使用了)。
如下:測試。我們新增上 @Data註解和 @AllArgsConstructor 註解。可以明顯的發現,預設的無引數構造器被覆蓋掉了
所以我們需要新增上:@NoArgsConstructor註解,因為@NoArgsConstructor註解,在編譯時,會生成無參構造器(一定會生成),不會受到其它的影響,被覆蓋。如圖
3. 在 idea 中 安裝 lombok外掛
不裝外掛也可以用基本的註解比如:@Data,@Getter...
但是不能使用其擴充套件功能,比如日誌輸出...,所以我們還是安裝一下,也比較簡單。
直接去外掛商城,搜尋: Lombok 即可
package com.rainbowsea.springboot.controller;
import com.rainbowsea.springboot.bean.Furn;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@Slf4j
@RestController // @Controller + @ResponseBody
public class HiController {
@Autowired
private Furn furn;
@RequestMapping("/hi") // 設定請求對映路徑
public String hi(){
log.info("furn-"+furn);
// 佔位符方式輸出
log.info("furn={} myfurn={}",furn,furn);
return "hi word";
// 使用 slf4j日誌輸出
}
}
執行測試:
4. 總結:
- 熟悉常用的 Lombok 註解,提供開發效率。
- 基本上@註解都會生成一個預設的無參構造器,但是當存在多個註解的時候,這個預設的無參構造器,可能會被覆蓋掉,從而導致無法不會被生成。但是,框架的上的使用,基本上都是需要使用上反射 機制的,而反射機制是必須要有一個無參構造器 才可以進行反射,獲取到對應的 Bean物件。給框架使用。所以,一般的 bean 物件都會新增上一個@NoArgsConstructor註解該在編譯時,會生成無參構造器(一定會生成),不會受到其它的
6. 最後:
“在這個最後的篇章中,我要表達我對每一位讀者的感激之情。你們的關注和回覆是我創作的動力源泉,我從你們身上吸取了無盡的靈感與勇氣。我會將你們的鼓勵留在心底,繼續在其他的領域奮鬥。感謝你們,我們總會在某個時刻再次相遇。”