自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

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

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

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

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

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

網(wǎng)上文章大部分都是介紹兩者的區(qū)別,沒有提到為什么,今天來總結(jié)一下

1.Spring常見的DI方式

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

@Autowired VS @Resource

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

依賴識(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提供的

2.各種DI方式的優(yōu)缺點(diǎn)

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

  • 構(gòu)造器注入:強(qiáng)依賴性(即必須使用此依賴),不變性(各依賴不會(huì)經(jīng)常變動(dòng))
  • Setter注入:可選(沒有此依賴也可以工作),可變(依賴會(huì)經(jīng)常變動(dòng))
  • Field注入:大多數(shù)情況下盡量少使用字段注入,一定要使用的話, @Resource相對(duì)@Autowired對(duì)IoC容器的耦合更低

3.Field注入的缺點(diǎn)

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

為什么IDEA只對(duì)@Autowired警告

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

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

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

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

責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2024-11-29 08:20:22

Autowired場景項(xiàng)目

2025-02-24 10:36:15

2021-08-23 13:02:50

MySQLJOIN數(shù)據(jù)庫

2009-06-11 17:03:22

Spring起源Spring優(yōu)點(diǎn)

2023-09-07 17:06:21

@Autowired報(bào)錯(cuò)原因分析

2024-11-12 10:30:54

Docker部署數(shù)據(jù)庫

2024-06-04 00:10:00

開發(fā)拷貝

2024-08-19 08:16:57

@Resource@AutowiredSpring

2022-12-26 00:00:03

非繼承關(guān)系JDK

2024-09-12 08:32:42

2011-04-15 09:44:45

Spring

2024-05-27 00:19:47

2025-02-14 00:00:25

C#后端RPS

2023-11-06 13:04:59

Python日志庫

2024-06-14 08:00:46

2009-06-15 17:48:32

Spring注解注入屬性

2017-12-15 14:10:20

深度學(xué)習(xí)本質(zhì)邊緣識(shí)別

2021-08-04 17:20:30

阿里巴巴AsyncJava

2021-11-11 15:25:28

@AsyncJava線程池

2021-06-03 10:58:16

logbacklog4jJava
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)