spring?和?idea?建議不要使用?@Autowired注解的原因解析
前言
這是我在這個網(wǎng)站整理的筆記,有錯誤的地方請指出,關(guān)注我,接下來還會持續(xù)更新。 作者:神的孩子都在歌唱
一. 問題描述
公司項目閑下來了之后,我就開始整理之前寫過的代碼,發(fā)現(xiàn)每個Autowired下面都有警告,**Field injection is not recommended(不建議使用字段注入)**這是什么意思呢?
二. 警告原因和如何去除
百度了一圈,以下是我總結(jié)的問題答案
雖然 @Autowired
是 Spring Boot 中最常用的依賴注入方式之一,但是在實際開發(fā)中,建議盡量避免使用 @Autowired
,而是使用構(gòu)造函數(shù)注入或者 @Resource
注解注入。
以下是使用 @Autowired
存在的一些問題:
- 不夠明確:在使用
@Autowired
進行依賴注入時,Spring 會自動根據(jù)類型來匹配 Bean,如果存在多個類型相同的 Bean,就會產(chǎn)生歧義。此時,需要使用@Qualifier
注解或者@Primary
注解來指定具體的 Bean。但是,這種方式不夠明確,容易出現(xiàn)錯誤。 - 難以測試:使用
@Autowired
進行依賴注入時,需要在測試中手動創(chuàng)建 Bean,并將其注入到測試類中。這種方式比較麻煩,而且容易出現(xiàn)錯誤。 - 無法保證依賴注入的順序:在使用
@Autowired
進行依賴注入時,Spring 會根據(jù) Bean 的創(chuàng)建順序來注入依賴,這種方式無法保證依賴注入的順序。
因此,在實際開發(fā)中,建議使用構(gòu)造函數(shù)注入或者 @Resource
注解注入。這種方式更加明確、易于測試,并且可以保證依賴注入的順序,所以idea不建議使用Autowired
注入了。
例如,使用構(gòu)造函數(shù)注入的方式可以這樣寫:
@Service public class UserService { private final UserRepository userRepository; public UserService(UserRepository userRepository) { this.userRepository = userRepository; } // ... }
或者使用 @Resource
注解注入的方式可以這樣寫:
@Service public class UserService { @Resource private UserRepository userRepository; // ... }
這些方式都可以避免使用 @Autowired
帶來的警告問題。
三. 個人的收獲和解決方案
3. 1 個人感受
參考了很多個文章之后,我不在使用autowired,對我來說使用autowired最大的問題是會寫出很多個循環(huán)依賴出來,雖然Spring 使用了三級緩存來處理循環(huán)依賴,項目也能夠正常運行,但是這樣會導(dǎo)致很多循環(huán)依賴問題我們發(fā)現(xiàn)不了,寫出很多不規(guī)范的代碼。每個模塊之間應(yīng)該是分層的,每個模塊、類或方法應(yīng)該只負(fù)責(zé)一個明確的功能或任務(wù),遵循單一職責(zé)。
像以下循環(huán)依賴的報錯,使用autowired就能夠解決
以上是我的收獲,不知道有沒有理解錯誤的地方,希望大家指出
3.2 通過構(gòu)造函數(shù)解決警告問題
為了消除警告,避免寫出循環(huán)依賴的代碼,我就使用了構(gòu)造函數(shù)注入,以下是我項目中使用的方式,通過
@RequiredArgsConstructor
可以減少很多代碼
@RequiredArgsConstructor
是Lombok框架中的注解之一,用于自動生成一個包含所有必需參數(shù)的構(gòu)造函數(shù)。它可以幫助開發(fā)人員減少代碼量,避免手動編寫構(gòu)造函數(shù)。使用@RequiredArgsConstructor
注解時,Lombok會自動檢測類中所有被聲明為final
的字段,并將其作為構(gòu)造函數(shù)的參數(shù)。生成的構(gòu)造函數(shù)將使用這些參數(shù)來初始化字段。
例如,下面是一個使用@RequiredArgsConstructor
注解:
@RequiredArgsConstructor public class MyService { private final MyRepository myRepository; private final MyLogger myLogger; // ... }
@RequiredArgsConstructor
注解會自動生成一個構(gòu)造函數(shù),該構(gòu)造函數(shù)包含兩個參數(shù):myRepository
和myLogger
。這兩個參數(shù)都是被聲明為final
的字段,因此它們將被用于初始化相應(yīng)的字段。
生成的構(gòu)造函數(shù)等效于以下代碼:
public class MyService { private final MyRepository myRepository; private final MyLogger myLogger; public MyService(MyRepository myRepository, MyLogger myLogger) { this.myRepository = myRepository; this.myLogger = myLogger; } // ... }
使用@RequiredArgsConstructor
注解可以讓開發(fā)人員更快地編寫代碼,并避免手動編寫構(gòu)造函數(shù)。將字段聲明為final
,以確保不可變性和線程安全性。
四. 小知識
4.1 使用@Autowired還會出現(xiàn)循環(huán)依賴的問題么
使用 @Autowired 仍然可能會出現(xiàn)循環(huán)依賴的問題。
Spring 容器在初始化時會先實例化所有的 bean,然后再進行依賴注入。如果 A bean 依賴了 B bean,而 B bean 又依賴了 A bean,就會出現(xiàn)循環(huán)依賴的問題。為了解決這個問題,Spring 使用了三級緩存來處理循環(huán)依賴。當(dāng)容器在初始化 A bean 時,如果發(fā)現(xiàn)它依賴了 B bean,就會先創(chuàng)建一個 A bean 的代理對象,然后將代理對象放入第一級緩存中。接著容器會創(chuàng)建 B bean,并將其注入到 A bean 的代理對象中。最后再將 A bean 的代理對象注入到 B bean 中。但是,如果循環(huán)依賴的鏈條過長,就有可能導(dǎo)致 Spring 容器無法解決循環(huán)依賴的問題,此時就會拋出 BeanCurrentlyInCreationException 異常。因此,在使用 @Autowired 進行依賴注入時,需要注意避免出現(xiàn)循環(huán)依賴的情況。
4.2 @Autowired 和 @Resource區(qū)別
- @Autowired 是 Spring 框架的注解,而 @Resource 是 JavaEE 的注解。
- @Autowired 默認(rèn)按照類型進行匹配,如果有多個同類型的 bean,則可以通過 @Qualifier 指定具體的 bean 名稱。而 @Resource 默認(rèn)按照名稱進行匹配,如果名稱匹配不到,則可以通過 name 屬性指定具體的 bean 名稱。
- @Autowired 可以用在構(gòu)造方法、setter 方法、字段上,而 @Resource 只能用在字段上。
- @Autowired 是 Spring 框架的特有功能,而 @Resource 是 JavaEE 的標(biāo)準(zhǔn)功能,在使用時需要注意兼容性問題。
- 都可以用于依賴注入
到此這篇關(guān)于spring 和 idea 建議不要使用 @Autowired注解的文章就介紹到這了,更多相關(guān)spring和 idea 不使用 @Autowired注解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java基于阻塞隊列實現(xiàn)生產(chǎn)者消費者模型示例詳解
這篇文章主要介紹了Java基于阻塞隊列實現(xiàn)生產(chǎn)者消費者模型,阻塞隊列的特點就是阻塞兩個字,阻塞功能使得生產(chǎn)者和消費者兩端的能力得以平衡,當(dāng)有任何一端速度過快時,阻塞隊列便會把過快的速度降下來,感興趣的朋友可以參考下2023-12-12java.lang.IllegalStateException:方法有太多主體參數(shù)問題
這篇文章主要介紹了java.lang.IllegalStateException:方法有太多主體參數(shù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07解析rainbond以應(yīng)用為中心的架構(gòu)設(shè)計原理
這篇文章主要為大家介紹了rainbond以應(yīng)用為中心的架構(gòu)設(shè)計實現(xiàn)及原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-02-02Spring+Mybatis 實現(xiàn)aop數(shù)據(jù)庫讀寫分離與多數(shù)據(jù)庫源配置操作
這篇文章主要介紹了Spring+Mybatis 實現(xiàn)aop數(shù)據(jù)庫讀寫分離與多數(shù)據(jù)庫源配置操作,需要的朋友可以參考下2017-09-09