解析Idea為什么不推薦使用@Autowired進(jìn)行Field注入
大家在使用IDEA開(kāi)發(fā)的時(shí)候有沒(méi)有注意到過(guò)一個(gè)提示,在字段上使用Spring的依賴(lài)注入注解@Autowired
后會(huì)出現(xiàn)如下警告
Field injection is not recommended (字段注入是不被推薦的)
但是使用@Resource
卻不會(huì)出現(xiàn)此提示
網(wǎng)上文章大部分都是介紹兩者的區(qū)別,沒(méi)有提到為什么,當(dāng)時(shí)想了好久想出了可能的原因,今天來(lái)總結(jié)一下
Spring常見(jiàn)的DI方式
- 構(gòu)造器注入:利用構(gòu)造方法的參數(shù)注入依賴(lài)
- Setter注入:調(diào)用Setter的方法注入依賴(lài)
- 字段注入:在字段上使用@Autowired/Resource注解
@Autowired VS @Resource
事實(shí)上,他們的基本功能都是通過(guò)注解實(shí)現(xiàn)依賴(lài)注入,只不過(guò)@Autowired
是Spring
定義的,而@Resource
是JSR-250
定義的。大致功能基本相同,但是還有一些細(xì)節(jié)不同:
- 依賴(lài)識(shí)別方式:@Autowired默認(rèn)是byType可以使用@Qualifier指定Name,@Resource默認(rèn)ByName如果找不到則ByType
- 適用對(duì)象:@Autowired可以對(duì)構(gòu)造器、方法、參數(shù)、字段使用,@Resource只能對(duì)方法、字段使用
- 提供方:@Autowired是Spring提供的,@Resource是JSR-250提供的
各種DI方式的優(yōu)缺點(diǎn)
參考Spring官方文檔,建議了如下的使用場(chǎng)景:
- 構(gòu)造器注入:強(qiáng)依賴(lài)性(即必須使用此依賴(lài)),不變性(各依賴(lài)不會(huì)經(jīng)常變動(dòng))
- Setter注入:可選(沒(méi)有此依賴(lài)也可以工作),可變(依賴(lài)會(huì)經(jīng)常變動(dòng))
- Field注入:大多數(shù)情況下盡量少使用字段注入,一定要使用的話(huà), @Resource相對(duì)@Autowired對(duì)IoC容器的耦合更低
Field注入的缺點(diǎn)
- 不能像構(gòu)造器那樣注入不可變的對(duì)象
- 依賴(lài)對(duì)外部不可見(jiàn),外界可以看到構(gòu)造器和setter,但無(wú)法看到私有字段,自然無(wú)法了解所需依賴(lài)
- 會(huì)導(dǎo)致組件與IoC容器緊耦合(這是最重要的原因,離開(kāi)了IoC容器去使用組件,在注入依賴(lài)時(shí)就會(huì)十分困難)
- 導(dǎo)致單元測(cè)試也必須使用IoC容器,原因同上
- 依賴(lài)過(guò)多時(shí)不夠明顯,比如我需要10個(gè)依賴(lài),用構(gòu)造器注入就會(huì)顯得龐大,這時(shí)候應(yīng)該考慮一下此組件是不是違反了單一職責(zé)原則
為什么IDEA只對(duì)@Autowired警告
Field注入雖然有很多缺點(diǎn),但它的好處也不可忽略:那就是太方便了。使用構(gòu)造器或者setter注入需要寫(xiě)更多業(yè)務(wù)無(wú)關(guān)的代碼,十分麻煩,而字段注入大幅簡(jiǎn)化了它們。并且絕大多數(shù)情況下業(yè)務(wù)代碼和框架就是強(qiáng)綁定的,完全松耦合只是一件理想上的事,犧牲了敏捷度去過(guò)度追求松耦合反而得不償失。
那么問(wèn)題來(lái)了,為什么IDEA只對(duì)@Autowired警告,卻對(duì)@Resource視而不見(jiàn)呢?
個(gè)人認(rèn)為,就像我們前面提到過(guò)的: @Autowired是Spring提供的,它是特定IoC提供的特定注解,這就導(dǎo)致了應(yīng)用與框架的強(qiáng)綁定,一旦換用了其他的IoC框架,是不能夠支持注入的。而 @Resource是JSR-250提供的,它是Java標(biāo)準(zhǔn),我們使用的IoC容器應(yīng)當(dāng)去兼容它,這樣即使更換容器,也可以正常工作。
到此這篇關(guān)于Idea不推薦使用@Autowired進(jìn)行Field注入的原因的文章就介紹到這了,更多相關(guān)Idea不推薦使用@Autowired注入內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IDEA maven依賴(lài)錯(cuò)誤中包下面紅色波浪線(xiàn)
這篇文章主要介紹了IDEA maven依賴(lài)錯(cuò)誤中包下面紅色波浪線(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08Java線(xiàn)程池7個(gè)參數(shù)的詳細(xì)含義
java多線(xiàn)程開(kāi)發(fā)時(shí),常常用到線(xiàn)程池技術(shù),這篇文章是對(duì)創(chuàng)建java線(xiàn)程池時(shí)的七個(gè)參數(shù)的詳細(xì)解釋?zhuān)哂幸欢ǖ膮⒖純r(jià)值,感興趣的小伙伴們可以參考一下2022-03-03SpringBoot開(kāi)發(fā)案例 分布式集群共享Session詳解
這篇文章主要介紹了SpringBoot開(kāi)發(fā)案例 分布式集群共享Session詳解,在分布式系統(tǒng)中,為了提升系統(tǒng)性能,通常會(huì)對(duì)單體項(xiàng)目進(jìn)行拆分,分解成多個(gè)基于功能的微服務(wù),可能還會(huì)對(duì)單個(gè)微服務(wù)進(jìn)行水平擴(kuò)展,保證服務(wù)高可用,需要的朋友可以參考下2019-07-07使用RequestBodyAdvice實(shí)現(xiàn)對(duì)Http請(qǐng)求非法字符過(guò)濾
這篇文章主要介紹了使用RequestBodyAdvice實(shí)現(xiàn)對(duì)Http請(qǐng)求非法字符過(guò)濾的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06SpringBoot靜態(tài)資源css,js,img配置方案
這篇文章主要介紹了SpringBoot靜態(tài)資源css,js,img配置方案,下文給大家分享了三種解決方案,需要的朋友可以參考下2017-07-07springboot jpa 延遲加載問(wèn)題的2種解決
這篇文章主要介紹了springboot jpa 延遲加載問(wèn)題的2種解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07Spring中@Import的各種用法以及ImportAware接口詳解
這篇文章主要介紹了Spring中@Import的各種用法以及ImportAware接口詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10Java編寫(xiě)計(jì)算器的常見(jiàn)方法實(shí)例總結(jié)
這篇文章主要介紹了Java編寫(xiě)計(jì)算器的常見(jiàn)方法,結(jié)合實(shí)例形式總結(jié)分析了Java實(shí)現(xiàn)計(jì)算器功能的常用方法,需要的朋友可以參考下2016-04-04