當(dāng)前位置:首頁 > 公眾號(hào)精選 > 程序員小灰
[導(dǎo)讀]@Autowired注解相信每個(gè)Spring開發(fā)者都不陌生了!在DD的SpringBoot基礎(chǔ)教程(https://blog.didispace.com/spring-boot-learning-2x/)和SpringCloud基礎(chǔ)教程(https://blog.didispac...

@Autowired注解相信每個(gè)Spring開發(fā)者都不陌生了!在DD的Spring Boot基礎(chǔ)教程https://blog.didispace.com/spring-boot-learning-2x/和Spring Cloud基礎(chǔ)教程(https://blog.didispace.com/spring-cloud-learning/)中也都經(jīng)常會(huì)出現(xiàn)。

但是當(dāng)我們使用IDEA寫代碼的時(shí)候,經(jīng)常會(huì)發(fā)現(xiàn)@Autowired注解下面是有小黃線的,我們把小鼠標(biāo)懸停在上面,可以看到這個(gè)如下圖所示的警告信息:

那為什么IDEA會(huì)給出Field injection is not recommended這樣的警告呢?

下面帶著這樣的問題,一起來全面的了解下Spring中的三種注入方式以及他們之間在各方面的優(yōu)劣。

Spring中的三種依賴注入方式

Field Injection

@Autowired注解的一大使用場景就是Field Injection。

具體形式如下:

@Controller
public?class?UserController?{

????@Autowired
????private?UserService?userService;

}

這種注入方式通過Java的反射機(jī)制實(shí)現(xiàn),所以private的成員也可以被注入具體的對(duì)象。

Constructor Injection

Constructor Injection是構(gòu)造器注入,是我們?nèi)粘W顬橥扑]的一種使用方式。

具體形式如下:

@Controller
public?class?UserController?{

????private?final?UserService?userService;

????public?UserController(UserService?userService){
????????this.userService?=?userService;
????}

}

這種注入方式很直接,通過對(duì)象構(gòu)建的時(shí)候建立關(guān)系,所以這種方式對(duì)對(duì)象創(chuàng)建的順序會(huì)有要求,當(dāng)然Spring會(huì)為你搞定這樣的先后順序,除非你出現(xiàn)循環(huán)依賴,然后就會(huì)拋出異常。

Setter Injection

Setter Injection也會(huì)用到@Autowired注解,但使用方式與Field Injection有所不同,Field Injection是用在成員變量上,而Setter Injection的時(shí)候,是用在成員變量的Setter函數(shù)上。

具體形式如下:

@Controller
public?class?UserController?{

????private?UserService?userService;

????@Autowired
????public?void?setUserService(UserService?userService){
????????this.userService?=?userService;
????}
}

這種注入方式也很好理解,就是通過調(diào)用成員變量的set方法來注入想要使用的依賴對(duì)象。

三種依賴注入的對(duì)比

在知道了Spring提供的三種依賴注入方式之后,我們繼續(xù)回到本文開頭說到的問題:IDEA為什么不推薦使用Field Injection呢?

我們可以從多個(gè)開發(fā)測試的考察角度來對(duì)比一下它們之間的優(yōu)劣:

可靠性

從對(duì)象構(gòu)建過程和使用過程,看對(duì)象在各階段的使用是否可靠來評(píng)判:

  • Field Injection:不可靠
  • Constructor Injection:可靠
  • Setter Injection:不可靠
由于構(gòu)造函數(shù)有嚴(yán)格的構(gòu)建順序和不可變性,一旦構(gòu)建就可用,且不會(huì)被更改。

可維護(hù)性

主要從更容易閱讀、分析依賴關(guān)系的角度來評(píng)判:

  • Field Injection:差
  • Constructor Injection:好
  • Setter Injection:差
還是由于依賴關(guān)鍵的明確,從構(gòu)造函數(shù)中可以顯現(xiàn)的分析出依賴關(guān)系,對(duì)于我們?nèi)绾稳プx懂關(guān)系和維護(hù)關(guān)系更友好。

可測試性

當(dāng)在復(fù)雜依賴關(guān)系的情況下,考察程序是否更容易編寫單元測試來評(píng)判

  • Field Injection:差
  • Constructor Injection:好
  • Setter Injection:好
Constructor InjectionSetter Injection的方式更容易Mock和注入對(duì)象,所以更容易實(shí)現(xiàn)單元測試。

靈活性

主要根據(jù)開發(fā)實(shí)現(xiàn)時(shí)候的編碼靈活性來判斷:

  • Field Injection:很靈活
  • Constructor Injection:不靈活
  • Setter Injection:很靈活
由于Constructor Injection對(duì)Bean的依賴關(guān)系設(shè)計(jì)有嚴(yán)格的順序要求,所以這種注入方式不太靈活。相反Field InjectionSetter Injection就非常靈活,但也因?yàn)殪`活帶來了局面的混亂,也是一把雙刃劍。

循環(huán)關(guān)系的檢測

對(duì)于Bean之間是否存在循環(huán)依賴關(guān)系的檢測能力:

  • Field Injection:不檢測
  • Constructor Injection:自動(dòng)檢測
  • Setter Injection:不檢測
性能表現(xiàn)

不同的注入方式,對(duì)性能的影響

  • Field Injection:啟動(dòng)快
  • Constructor Injection:啟動(dòng)慢
  • Setter Injection:啟動(dòng)快
主要影響就是啟動(dòng)時(shí)間,由于Constructor Injection有嚴(yán)格的順序要求,所以會(huì)拉長啟動(dòng)時(shí)間。

所以,綜合上面各方面的比較,可以獲得如下表格:

結(jié)果一目了然,Constructor Injection在很多方面都是優(yōu)于其他兩種方式的,所以Constructor Injection通常都是首選方案!

Setter Injection比起Field Injection來說,大部分都一樣,但因?yàn)榭蓽y試性更好,所以當(dāng)你要用@Autowired的時(shí)候,推薦使用Setter Injection的方式,這樣IDEA也不會(huì)給出警告了。同時(shí),也側(cè)面反映了,可測試性的重要地位啊!

總結(jié)

最后,對(duì)于今天的問題討論,我們給出兩個(gè)結(jié)論,方便大家記憶:

  1. 依賴注入的使用上,Constructor Injection是首選。
  2. 使用@Autowired注解的時(shí)候,要使用Setter Injection方式,這樣代碼更容易編寫單元測試。
好了,今天的學(xué)習(xí)就到這里。記得讀完點(diǎn)一下“在看”,加個(gè)“星標(biāo)”,這樣每次新文章推送才會(huì)第一時(shí)間出現(xiàn)在你的訂閱列表里。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉