吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Spring常見的DI方式

倩倩 ? 來源:juejin.cn ? 作者:juejin.cn ? 2022-09-07 11:01 ? 次閱讀


大家在使用IDEA開發(fā)的時候有沒有注意到過一個提示,在字段上使用Spring的依賴注入注解@Autowired后會出現(xiàn)如下警告

Field injection is not recommended (字段注入是不被推薦的)

但是使用@Resource卻不會出現(xiàn)此提示

網(wǎng)上文章大部分都是介紹兩者的區(qū)別,沒有提到為什么,當(dāng)時想了好久想出了可能的原因,今天來總結(jié)一下

Spring常見的DI方式

  • 構(gòu)造器注入 :利用構(gòu)造方法的參數(shù)注入依賴
  • Setter注入 :調(diào)用Setter的方法注入依賴
  • 字段注入 :在字段上使用@Autowired/Resource注解

@Autowired VS @Resource

事實上,他們的基本功能都是通過注解實現(xiàn)依賴注入 ,只不過@AutowiredSpring定義的,而@ResourceJSR-250定義的。大致功能基本相同,但是還有一些細節(jié)不同:

  • 依賴識別方式@Autowired默認是byType 可以使用@Qualifier指定Name,@Resource默認ByName 如果找不到則ByType
  • 適用對象@Autowired可以對構(gòu)造器、方法、參數(shù)、字段 使用,@Resource只能對方法、字段 使用
  • 提供方@AutowiredSpring 提供的,@ResourceJSR-250 提供的

基于 Spring Boot + MyBatis Plus + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://gitee.com/zhijiantianya/ruoyi-vue-pro
  • 視頻教程:https://doc.iocoder.cn/video/

各種DI方式的優(yōu)缺點

參考Spring官方文檔,建議了如下的使用場景:

  • 構(gòu)造器注入強依賴性 (即必須使用此依賴),不變性 (各依賴不會經(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)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

  • 項目地址:https://gitee.com/zhijiantianya/yudao-cloud
  • 視頻教程:https://doc.iocoder.cn/video/

Field注入的缺點

  • 不能像構(gòu)造器那樣注入不可變的對象
  • 依賴對外部不可見 ,外界可以看到構(gòu)造器和setter,但無法看到私有字段,自然無法了解所需依賴
  • 會導(dǎo)致組件與IoC容器緊耦合 (這是最重要的原因,離開了IoC容器去使用組件,在注入依賴時就會十分困難)
  • 導(dǎo)致單元測試也必須使用IoC容器 ,原因同上
  • 依賴過多時不夠明顯 ,比如我需要10個依賴,用構(gòu)造器注入就會顯得龐大,這時候應(yīng)該考慮一下此組件是不是違反了單一職責(zé)原則

為什么IDEA只對@Autowired警告

Field注入雖然有很多缺點,但它的好處也不可忽略:那就是太方便了 。使用構(gòu)造器或者setter注入需要寫更多業(yè)務(wù)無關(guān)的代碼,十分麻煩,而字段注入大幅簡化了它們。并且絕大多數(shù)情況下業(yè)務(wù)代碼和框架就是強綁定的,完全松耦合只是一件理想上的事,犧牲了敏捷度去過度追求松耦合反而得不償失。

那么問題來了,為什么IDEA只對@Autowired警告,卻對@Resource視而不見呢?

個人認為 ,就像我們前面提到過的:@AutowiredSpring 提供的,它是特定IoC提供的特定注解 ,這就導(dǎo)致了應(yīng)用與框架的強綁定 ,一旦換用了其他的IoC框架,是不能夠支持注入 的。

@ResourceJSR-250 提供的,它是Java標(biāo)準(zhǔn) ,我們使用的IoC容器應(yīng)當(dāng)去兼容它,這樣即使更換容器,也可以正常工作。



審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 容器
    +關(guān)注

    關(guān)注

    0

    文章

    499

    瀏覽量

    22125
  • spring
    +關(guān)注

    關(guān)注

    0

    文章

    340

    瀏覽量

    14391

原文標(biāo)題:為什么 Spring和IDEA 都不推薦使用 @Autowired 注解

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    SSM開發(fā)中的常見問題及解決方案

    在SSM(Spring + Spring MVC + MyBatis)框架的開發(fā)過程中,開發(fā)者可能會遇到一些常見問題。以下是對這些問題的詳細分析以及相應(yīng)的解決方案: 一、配置文件問題 問題描述
    的頭像 發(fā)表于 12-17 09:16 ?565次閱讀

    Spring 應(yīng)用合并之路(二):峰回路轉(zhuǎn),柳暗花明

    作者:京東科技 李君 書接上文,前面在 Spring 應(yīng)用合并之路(一):摸石頭過河 介紹了幾種不成功的經(jīng)驗,下面繼續(xù)折騰… 四、倉庫合并,獨立容器 在經(jīng)歷了上面的嘗試,在同事為啥不搞兩個獨立的容器
    的頭像 發(fā)表于 12-12 11:22 ?836次閱讀

    示波器接口和連接方式 示波器的常見故障及解決方法

    示波器接口和連接方式 示波器是一種用于觀察和分析電信號波形的電子測量儀器。它通過接口和連接方式與被測設(shè)備相連,以獲取信號并顯示在屏幕上。以下是一些常見的示波器接口和連接方式: 1. B
    的頭像 發(fā)表于 11-28 09:38 ?1047次閱讀

    常見人體姿態(tài)評估顯示方式的兩種方式

    人體姿態(tài)評估中有兩種常見的顯示方式,分別是火柴人效果與BodyPix效果。其中火柴人效果本質(zhì)就是基于關(guān)鍵點的深度學(xué)習(xí)模型推理以后的顯示效果;Bodypix本質(zhì)就就是語義分割模型
    的頭像 發(fā)表于 11-11 11:21 ?281次閱讀
    <b class='flag-5'>常見</b>人體姿態(tài)評估顯示<b class='flag-5'>方式</b>的兩種<b class='flag-5'>方式</b>

    Spring事務(wù)實現(xiàn)原理

    這些操作。 spring事務(wù)有編程式事務(wù)和聲明式事務(wù)兩種實現(xiàn)方式。編程式事務(wù)是通過編寫代碼來管理事務(wù)的提交、回滾、以及事務(wù)的邊界。這意味著開發(fā)者需要在代碼中顯式地調(diào)用事務(wù)的開始、提交和回滾。聲明式事務(wù)是通過配置來管理事務(wù),您可以使用注解或XML配置來
    的頭像 發(fā)表于 11-08 10:10 ?874次閱讀
    <b class='flag-5'>Spring</b>事務(wù)實現(xiàn)原理

    Spring Cloud Gateway網(wǎng)關(guān)框架

    Spring Cloud Gateway網(wǎng)關(guān)框架 本軟件微服務(wù)架構(gòu)中采用Spring Cloud Gateway網(wǎng)關(guān)控制框架,Spring Cloud Gateway是Spring C
    的頭像 發(fā)表于 08-22 09:58 ?545次閱讀
    <b class='flag-5'>Spring</b> Cloud Gateway網(wǎng)關(guān)框架

    嵌入式QT常見開發(fā)方式有哪些?

    嵌入式QT常見開發(fā)方式有哪些? 嵌入式工程師在學(xué)習(xí)和使用Qt進行開發(fā)時,常見的幾種開發(fā)方式包括: 1.Qt Widgets編程: 通過C++代碼直接編寫GUI應(yīng)用程序,利用QtWi
    發(fā)表于 08-12 10:05

    多級放大電路常見的耦合方式有哪些

    多級放大電路是電子電路中常見的一種電路結(jié)構(gòu),它由多個放大器級聯(lián)而成,以實現(xiàn)對信號的多級放大。耦合方式是多級放大電路中的關(guān)鍵技術(shù)之一,它決定了信號在各個放大器之間如何傳遞。本文將介紹多級放大電路常見
    的頭像 發(fā)表于 08-07 10:10 ?1095次閱讀

    常見的傳感器接線方式有哪些

    信息的傳輸、處理、存儲、顯示、記錄和控制等要求。常見的傳感器接線方式主要包括兩線制、三線制和四線制,每種方式都有其特定的應(yīng)用場景和接線規(guī)則。
    的頭像 發(fā)表于 07-30 11:50 ?1696次閱讀

    玩轉(zhuǎn)Spring狀態(tài)機

    說起Spring狀態(tài)機,大家很容易聯(lián)想到這個狀態(tài)機和設(shè)計模式中狀態(tài)模式的區(qū)別是啥呢?沒錯,Spring狀態(tài)機就是狀態(tài)模式的一種實現(xiàn),在介紹Spring狀態(tài)機之前,讓我們來看看設(shè)計模式中的狀態(tài)模式
    的頭像 發(fā)表于 06-25 14:21 ?1031次閱讀
    玩轉(zhuǎn)<b class='flag-5'>Spring</b>狀態(tài)機

    PCBA加工中常見的兩種焊接方式詳解

    一站式PCBA智造廠家今天為大家講講PCBA加工手工焊接有哪幾種方式?PCBA加工過程中常用焊接方式。在PCBA(印刷電路板組裝)加工過程中,焊接是一個關(guān)鍵的步驟。而手工焊接作為一種常見的焊接
    的頭像 發(fā)表于 06-14 09:18 ?627次閱讀

    感應(yīng)電機的常見啟動方式

    感應(yīng)電機,作為現(xiàn)代工業(yè)領(lǐng)域中廣泛應(yīng)用的電力驅(qū)動設(shè)備,其啟動方式的選擇直接影響到電機的運行性能、使用壽命以及整個系統(tǒng)的穩(wěn)定性和效率。因此,了解和掌握感應(yīng)電機的常見啟動方式對于工程師和技術(shù)人員來說
    的頭像 發(fā)表于 06-05 15:19 ?1348次閱讀

    綜合網(wǎng)線常見接線方式和步驟

    綜合網(wǎng)線的接線方式主要根據(jù)具體的應(yīng)用場景和網(wǎng)絡(luò)設(shè)備類型來確定。以下是一些常見的接線方式和步驟: 直通網(wǎng)線接線: 直通網(wǎng)線是最常見的網(wǎng)線類型,用于連接不同類型的設(shè)備,如PC到交換機或路由
    的頭像 發(fā)表于 05-10 10:52 ?2724次閱讀

    鋇錸技術(shù)BL192 EtherCAT支持8路DI模塊NPN輸入

    BL190是一款鋇錸技術(shù)IOy系列高度靈活的Modbus TCP遠程IO系統(tǒng),專為工業(yè)自動化設(shè)計。用戶可以根據(jù)自己的需求自由組合1-3塊Y系列IO板。例如,BL190可以搭配3塊Y11(8DI)組成
    的頭像 發(fā)表于 03-08 15:07 ?464次閱讀
    鋇錸技術(shù)BL192  EtherCAT支持8路<b class='flag-5'>DI</b>模塊NPN輸入

    功放分幾種類型,功放常見分類方式

    功放(Power Amplifier)作為音頻設(shè)備中不可或缺的重要組成部分,廣泛應(yīng)用于音響系統(tǒng)、電視機、電子設(shè)備等多個領(lǐng)域。功放按照不同的分類方式可以分成多種類型,本文將細致地介紹功放的常見分類方式
    的頭像 發(fā)表于 02-23 10:58 ?5501次閱讀
    大发888娱乐场下载samplingid112| 做生意发财招财图像| 百家乐任你博娱乐场| 迪威百家乐官网现场| 百家乐官网轮盘桌| 哪家百家乐最好| 澳门百家乐官网经历| 大发888明星婚讯| 百家乐色子玩法| 呼玛县| 百家乐游戏辅助| 24个招财方法| 澳门百家乐官网论谈| 汇丰百家乐娱乐城| 巴比伦百家乐官网的玩法技巧和规则| 香港六合彩资料大全| 百家乐电投网站| 百家乐官网群1188999| 博彩网站排行| 路虎百家乐的玩法技巧和规则| 聚众玩百家乐官网的玩法技巧和规则 | 赌博百家乐官网赢钱方法| 太阳城在线娱乐城| 网上百家乐赌钱| 菲律宾百家乐官网试玩| 水果机遥控器价格| 利博百家乐破解| 百家乐官网平注常赢玩法技巧| 百家乐官网休闲游戏| 威尼斯人娱乐城网| 百家乐路纸发表区| 百家乐官网凯时娱乐场| 桓台县| 新乡市| 大发888娱乐博盈投资| 百家乐投注最好方法| 福布斯百家乐官网的玩法技巧和规则| 百家乐官网2号破解下载| 百家乐官网娱乐网站| 百家乐官网是骗人吗| 百胜百家乐官网软件|