解析Idea為什麼不推薦使用@Autowired進行Field註入
大傢在使用IDEA開發的時候有沒有註意到過一個提示,在字段上使用Spring的依賴註入註解@Autowired
後會出現如下警告
Field injection is not recommended (字段註入是不被推薦的)
但是使用@Resource
卻不會出現此提示
網上文章大部分都是介紹兩者的區別,沒有提到為什麼,當時想瞭好久想出瞭可能的原因,今天來總結一下
Spring常見的DI方式
- 構造器註入:利用構造方法的參數註入依賴
- Setter註入:調用Setter的方法註入依賴
- 字段註入:在字段上使用@Autowired/Resource註解
@Autowired VS @Resource
事實上,他們的基本功能都是通過註解實現依賴註入,隻不過@Autowired
是Spring
定義的,而@Resource
是JSR-250
定義的。大致功能基本相同,但是還有一些細節不同:
- 依賴識別方式:@Autowired默認是byType可以使用@Qualifier指定Name,@Resource默認ByName如果找不到則ByType
- 適用對象:@Autowired可以對構造器、方法、參數、字段使用,@Resource隻能對方法、字段使用
- 提供方:@Autowired是Spring提供的,@Resource是JSR-250提供的
各種DI方式的優缺點
參考Spring官方文檔,建議瞭如下的使用場景:
- 構造器註入:強依賴性(即必須使用此依賴),不變性(各依賴不會經常變動)
- Setter註入:可選(沒有此依賴也可以工作),可變(依賴會經常變動)
- Field註入:大多數情況下盡量少使用字段註入,一定要使用的話, @Resource相對@Autowired對IoC容器的耦合更低
Field註入的缺點
- 不能像構造器那樣註入不可變的對象
- 依賴對外部不可見,外界可以看到構造器和setter,但無法看到私有字段,自然無法瞭解所需依賴
- 會導致組件與IoC容器緊耦合(這是最重要的原因,離開瞭IoC容器去使用組件,在註入依賴時就會十分困難)
- 導致單元測試也必須使用IoC容器,原因同上
- 依賴過多時不夠明顯,比如我需要10個依賴,用構造器註入就會顯得龐大,這時候應該考慮一下此組件是不是違反瞭單一職責原則
為什麼IDEA隻對@Autowired警告
Field註入雖然有很多缺點,但它的好處也不可忽略:那就是太方便瞭。使用構造器或者setter註入需要寫更多業務無關的代碼,十分麻煩,而字段註入大幅簡化瞭它們。並且絕大多數情況下業務代碼和框架就是強綁定的,完全松耦合隻是一件理想上的事,犧牲瞭敏捷度去過度追求松耦合反而得不償失。
那麼問題來瞭,為什麼IDEA隻對@Autowired警告,卻對@Resource視而不見呢?
個人認為,就像我們前面提到過的: @Autowired是Spring提供的,它是特定IoC提供的特定註解,這就導致瞭應用與框架的強綁定,一旦換用瞭其他的IoC框架,是不能夠支持註入的。而 @Resource是JSR-250提供的,它是Java標準,我們使用的IoC容器應當去兼容它,這樣即使更換容器,也可以正常工作。
到此這篇關於Idea不推薦使用@Autowired進行Field註入的原因的文章就介紹到這瞭,更多相關Idea不推薦使用@Autowired註入內容請搜索LevelAH以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持LevelAH!
推薦閱讀:
- 淺談spring DI 依賴註入方式和區別
- Spring為什麼不推薦使用@Autowired註解詳析
- Java面試題沖刺第十八天–Spring框架3
- 一文搞懂Spring中@Autowired和@Resource的區別
- 深入分析@Resource和@Autowired註解區別