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

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

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

為什么Spring和IDEA都不推薦使用@Autowired注解

jf_ro2CN3Fa ? 來源:芋道源碼 ? 2023-06-06 17:00 ? 次閱讀

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

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

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

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

Spring常見的DI方式

構(gòu)造器注入:利用構(gòu)造方法的參數(shù)注入依賴

Setter注入:調(diào)用Setter的方法注入依賴

字段注入:在字段上使用@Autowired/Resource注解

@Autowired VS @Resource

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

依賴識別方式:@Autowired默認是byType可以使用@Qualifier指定Name,@Resource默認ByName如果找不到則ByType

適用對象:@Autowired可以對構(gòu)造器、方法、參數(shù)、字段使用,@Resource只能對方法、字段使用

提供方:@Autowired是Spring提供的,@Resource是JSR-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,但無法看到私有字段,自然無法了解所需依賴

會導致組件與IoC容器緊耦合(這是最重要的原因,離開了IoC容器去使用組件,在注入依賴時就會十分困難)

導致單元測試也必須使用IoC容器,原因同上

依賴過多時不夠明顯,比如我需要10個依賴,用構(gòu)造器注入就會顯得龐大,這時候應該考慮一下此組件是不是違反了單一職責原則

為什么IDEA只對@Autowired警告

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

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

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

而@Resource是JSR-250提供的,它是Java標準,我們使用的IoC容器應當去兼容它,這樣即使更換容器,也可以正常工作。

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

    關(guān)注

    0

    文章

    491

    瀏覽量

    22015
  • spring
    +關(guān)注

    關(guān)注

    0

    文章

    335

    瀏覽量

    14278
  • idea
    +關(guān)注

    關(guān)注

    1

    文章

    67

    瀏覽量

    4227

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

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

收藏 人收藏

    評論

    相關(guān)推薦

    Spring Boot如何實現(xiàn)異步任務

    Spring Boot 提供了多種方式來實現(xiàn)異步任務,這里介紹三種主要實現(xiàn)方式。 1、基于注解 @Async @Async 注解Spring 提供的一種輕量級異步方法實現(xiàn)方式,它可
    的頭像 發(fā)表于 09-30 10:32 ?1326次閱讀

    redis緩存注解怎么使用

    spring boot —— redis 緩存注解使用教程
    發(fā)表于 09-11 14:43

    Spring筆記分享

    Spring實現(xiàn)了使用簡單的組件配置組合成一個復雜的應用。在 Spring 中可以使用XML和Java注解組合這些對象。6) 一站式:在IOC和AOP的基礎(chǔ)上可以整合各種企業(yè)應用的開源框架和優(yōu)秀的第三方類
    發(fā)表于 11-04 07:51

    啟動Spring Boot項目應用的三種方法

    基礎(chǔ)。我們知道了Spring Boot是個什么了,那么我們又該如何啟動Spring Boot應用呢?這里小編給大家推薦常用的三種方法。分別是IDEA編輯器啟動、命令啟動、java命令jar文件啟動。下面
    發(fā)表于 01-14 17:33

    使用Spring自定義注解的實現(xiàn)

    執(zhí)行器。其本質(zhì)就是通過外部參數(shù)進行一次路由和Spring mvc做的事情類似。簡單看了Spring mvc的實現(xiàn)原理之后,決定使用自定義注解的方式來實現(xiàn)以上功能。 自定義TaskHandler
    發(fā)表于 09-28 11:55 ?0次下載

    Spring應用 1 springXML配置說明

    開發(fā)過程。會使用注解形式的開發(fā)模式。但使用相應的注解需要spring.xml中定義相應的BeanProcessor,這樣顯得很笨重。 使用@Autowired
    發(fā)表于 01-13 12:20 ?376次閱讀

    淺談Spring事務底層原理

    開啟Spring事務本質(zhì)上就是增加了一個Advisor,但我們使用@EnableTransactionManagement注解來開啟Spring事務是,該注解代理的功能就是向
    的頭像 發(fā)表于 12-06 09:56 ?654次閱讀

    Spring Web MVC注解

    RequestMapping注解的主要用途是將Web請求與請求處理類中的方法進行映射。Spring MVC和Spring WebFlux都通過`RquestMappingHandlerMapping`和`RequestMappi
    的頭像 發(fā)表于 04-07 11:32 ?556次閱讀
    <b class='flag-5'>Spring</b> Web MVC<b class='flag-5'>注解</b>

    Spring Bean相關(guān)的4個注解及使用方法

    ComponentScan`注解用于配置Spring需要掃描的被組件注解注釋的類所在的包。可以通過配置其basePackages屬性或者value屬性來配置需要掃描的包路徑。value屬性是basePackages的別名。此
    的頭像 發(fā)表于 04-07 11:33 ?1289次閱讀
    <b class='flag-5'>Spring</b> Bean相關(guān)的4個<b class='flag-5'>注解</b>及使用方法

    Spring Dependency Inject與Bean Scops注解

    DependsOn`注解可以配置Spring IoC容器在初始化一個Bean之前,先初始化其他的Bean對象。下面是此注解使用示例代碼:
    的頭像 發(fā)表于 04-07 11:35 ?640次閱讀
    <b class='flag-5'>Spring</b> Dependency Inject與Bean Scops<b class='flag-5'>注解</b>

    容器配置及Spring Boot注解

    Autowired注解用于標記Spring將要解析和注入的依賴項。此注解可以作用在構(gòu)造函數(shù)、字段和setter方法上。
    的頭像 發(fā)表于 04-07 11:45 ?534次閱讀
    容器配置及<b class='flag-5'>Spring</b> Boot<b class='flag-5'>注解</b>

    Spring中@Component注解是怎么實現(xiàn)的

    想必`@Component`注解大家一直在使用,只要類上加上它,就可以被Spring容器管理,那大家有想過它是怎么實現(xiàn)的嗎?本篇文章就帶領(lǐng)到家揭秘。
    的頭像 發(fā)表于 04-07 15:23 ?1492次閱讀
    <b class='flag-5'>Spring</b>中@Component<b class='flag-5'>注解</b>是怎么實現(xiàn)的

    為什么SpringIDEA都不推薦使用 @Autowired 注解?

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

    springboot核心注解

    Spring Boot 是基于 Spring 框架的開源框架,它可以幫助開發(fā)者快速構(gòu)建、部署和運行獨立的、生產(chǎn)級的 Spring 應用程序。Spring Boot 提供了一系列核心
    的頭像 發(fā)表于 11-23 09:23 ?471次閱讀

    SpringBoot核心注解由幾個注解組成

    簡化應用程序開發(fā)的注解,其中核心注解包括 @SpringBootApplication、@RestController、@RequestMapping、@Autowired、@ComponentScan
    的頭像 發(fā)表于 12-03 15:09 ?670次閱讀