大家在使用IDEA開發(fā)的時候有沒有注意到過一個提示,在字段上使用Spring的依賴注入注解@Autowired
后會出現(xiàn)如下警告
Field injection is not recommended (字段注入是不被推薦的)
但是使用@Resource
卻不會出現(xiàn)此提示
網(wǎng)上文章大部分都是介紹兩者的區(qū)別,沒有提到為什么,當時想了好久想出了可能的原因,今天來總結一下
-
構造器注入 :利用構造方法的參數(shù)注入依賴
-
Setter注入 :調(diào)用Setter的方法注入依賴
-
字段注入 :在字段上使用
@Autowired/Resource
注解
事實上,他們的基本功能都是通過注解實現(xiàn)依賴注入 ,只不過@Autowired
是Spring
定義的,而@Resource
是JSR-250
定義的。大致功能基本相同,但是還有一些細節(jié)不同:
-
依賴識別方式 :
@Autowired
默認是byType 可以使用@Qualifier
指定Name,@Resource
默認ByName 如果找不到則ByType
-
適用對象 :
@Autowired
可以對構造器、方法、參數(shù)、字段 使用,@Resource
只能對方法、字段 使用
-
提供方 :
@Autowired
是Spring 提供的,@Resource
是JSR-250 提供的
基于 Spring Boot + MyBatis Plus + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能
-
項目地址:https://gitee.com/zhijiantianya/ruoyi-vue-pro
-
視頻教程:https://doc.iocoder.cn/video/
參考Spring官方文檔,建議了如下的使用場景:
-
構造器注入 :強依賴性 (即必須使用此依賴),不變性 (各依賴不會經(jīng)常變動)
-
Setter注入 :可選 (沒有此依賴也可以工作),可變 (依賴會經(jīng)常變動)
-
Field注入 :大多數(shù)情況下盡量少使用 字段注入,一定要使用的話, @Resource相對@Autowired 對IoC容器的耦合更低
基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權限、多租戶、數(shù)據(jù)權限、工作流、三方登錄、支付、短信、商城等功能
-
項目地址:https://gitee.com/zhijiantianya/yudao-cloud
-
視頻教程:https://doc.iocoder.cn/video/
-
不能像構造器那樣注入不可變的對象
-
依賴對外部不可見 ,外界可以看到構造器和setter,但無法看到私有字段,自然無法了解所需依賴
-
會導致組件與IoC容器緊耦合 (這是最重要的原因,離開了IoC容器去使用組件,在注入依賴時就會十分困難)
-
導致單元測試也必須使用IoC容器 ,原因同上
-
依賴過多時不夠明顯 ,比如我需要10個依賴,用構造器注入就會顯得龐大,這時候應該考慮一下此組件是不是違反了單一職責原則
Field注入雖然有很多缺點,但它的好處也不可忽略:那就是太方便了 。使用構造器或者setter注入需要寫更多業(yè)務無關的代碼,十分麻煩,而字段注入大幅簡化了它們。并且絕大多數(shù)情況下業(yè)務代碼和框架就是強綁定的,完全松耦合只是一件理想上的事,犧牲了敏捷度去過度追求松耦合反而得不償失。
那么問題來了,為什么IDEA只對@Autowired警告,卻對@Resource視而不見呢?
個人認為 ,就像我們前面提到過的:@Autowired 是Spring 提供的,它是特定IoC提供的特定注解 ,這就導致了應用與框架的強綁定 ,一旦換用了其他的IoC框架,是不能夠支持注入 的。
而 @Resource 是JSR-250 提供的,它是Java標準 ,我們使用的IoC容器應當去兼容它,這樣即使更換容器,也可以正常工作。
審核編輯 :李倩
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報投訴
原文標題:為什么 Spring和IDEA 都不推薦使用 @Autowired 注解
文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
相關推薦
在SSM(Spring + Spring MVC + MyBatis)框架的開發(fā)過程中,開發(fā)者可能會遇到一些常見問題。以下是對這些問題的詳細分析以及相應的解決方案: 一、配置文件問題 問題描述
發(fā)表于 12-17 09:16
?485次閱讀
作者:京東科技 李君 書接上文,前面在 Spring 應用合并之路(一):摸石頭過河 介紹了幾種不成功的經(jīng)驗,下面繼續(xù)折騰… 四、倉庫合并,獨立容器 在經(jīng)歷了上面的嘗試,在同事為啥不搞兩個獨立的容器
發(fā)表于 12-12 11:22
?779次閱讀
示波器接口和連接方式 示波器是一種用于觀察和分析電信號波形的電子測量儀器。它通過接口和連接方式與被測設備相連,以獲取信號并顯示在屏幕上。以下是一些常見的示波器接口和連接方式: 1. B
發(fā)表于 11-28 09:38
?892次閱讀
這些操作。 spring事務有編程式事務和聲明式事務兩種實現(xiàn)方式。編程式事務是通過編寫代碼來管理事務的提交、回滾、以及事務的邊界。這意味著開發(fā)者需要在代碼中顯式地調(diào)用事務的開始、提交和回滾。聲明式事務是通過配置來管理事務,您可以使用注解或XML配置來
發(fā)表于 11-08 10:10
?852次閱讀
Spring Cloud Gateway網(wǎng)關框架 本軟件微服務架構中采用Spring Cloud Gateway網(wǎng)關控制框架,Spring Cloud Gateway是Spring C
發(fā)表于 08-22 09:58
?520次閱讀
嵌入式QT常見開發(fā)方式有哪些?
嵌入式工程師在學習和使用Qt進行開發(fā)時,常見的幾種開發(fā)方式包括:
1.Qt Widgets編程: 通過C++代碼直接編寫GUI應用程序,利用QtWi
發(fā)表于 08-12 10:05
多級放大電路是電子電路中常見的一種電路結構,它由多個放大器級聯(lián)而成,以實現(xiàn)對信號的多級放大。耦合方式是多級放大電路中的關鍵技術之一,它決定了信號在各個放大器之間如何傳遞。本文將介紹多級放大電路常見
發(fā)表于 08-07 10:10
?992次閱讀
信息的傳輸、處理、存儲、顯示、記錄和控制等要求。常見的傳感器接線方式主要包括兩線制、三線制和四線制,每種方式都有其特定的應用場景和接線規(guī)則。
發(fā)表于 07-30 11:50
?1512次閱讀
說起Spring狀態(tài)機,大家很容易聯(lián)想到這個狀態(tài)機和設計模式中狀態(tài)模式的區(qū)別是啥呢?沒錯,Spring狀態(tài)機就是狀態(tài)模式的一種實現(xiàn),在介紹Spring狀態(tài)機之前,讓我們來看看設計模式中的狀態(tài)模式
發(fā)表于 06-25 14:21
?986次閱讀
一站式PCBA智造廠家今天為大家講講PCBA加工手工焊接有哪幾種方式?PCBA加工過程中常用焊接方式。在PCBA(印刷電路板組裝)加工過程中,焊接是一個關鍵的步驟。而手工焊接作為一種常見的焊接
發(fā)表于 06-14 09:18
?586次閱讀
感應電機,作為現(xiàn)代工業(yè)領域中廣泛應用的電力驅(qū)動設備,其啟動方式的選擇直接影響到電機的運行性能、使用壽命以及整個系統(tǒng)的穩(wěn)定性和效率。因此,了解和掌握感應電機的常見啟動方式對于工程師和技術人員來說
發(fā)表于 06-05 15:19
?1264次閱讀
綜合網(wǎng)線的接線方式主要根據(jù)具體的應用場景和網(wǎng)絡設備類型來確定。以下是一些常見的接線方式和步驟: 直通網(wǎng)線接線: 直通網(wǎng)線是最常見的網(wǎng)線類型,用于連接不同類型的設備,如PC到交換機或路由
發(fā)表于 05-10 10:52
?1000次閱讀
功放(Power Amplifier)作為音頻設備中不可或缺的重要組成部分,廣泛應用于音響系統(tǒng)、電視機、電子設備等多個領域。功放按照不同的分類方式可以分成多種類型,本文將細致地介紹功放的常見分類方式
發(fā)表于 02-23 10:58
?5257次閱讀
無功補償?shù)脑怼⒆饔眉?b class='flag-5'>常見方式? 無功補償是電力系統(tǒng)中的一項重要技術措施,用于改善電力質(zhì)量和提高能源利用效率。本文將詳細介紹無功補償?shù)脑怼⒆饔靡约?b class='flag-5'>常見的補償方式。 一、無功補償?shù)脑?無功功率
發(fā)表于 01-19 14:19
?9627次閱讀
最常見的直流負載工作方式? 直流負載工作方式是指在直流電路中使用的各種負載方式。直流負載是用于測試和測量直流電源輸出能力和能效的設備,可以模擬真實負載條件下的電流和功率需求。本文將詳細
發(fā)表于 01-18 15:12
?826次閱讀
評論