在使用IDEA編寫Spring時, 遇到warning : Field injection is not recommended.
Field injection is not recommended
那么為什么不推薦Field Injection呢?
通常依賴注入方式有三種
- constructor
為了強制依賴,或者為了易變性,使用構造方法注入 - getter & setter
為了可選的或者可變的依賴,使用setter注入 - 通過反射直接注入到fields
@Autowired就是通過這種方式
盡量避免使用直接在屬性上注入
屬性注入的壞處
1、你不能使用屬性注入的方式構建不可變對象。
2、你的類和依賴容器強耦合,不能再容器外使用。
3、你的類不能繞過反射(例如單元測試的時候)進行實例化,必須通過依賴容器才能實例化。
4、實際的依賴被隱藏在外面,不是在構造方法或者其它方法里面反射的。
5、一個類經常會有超過10個的依賴。如果使用構造方法的方式注入的話,構造方法會有10個參數,明顯有點蠢。但是如果使用屬性注入的話就沒有這樣的限制。但是一個類有很多的依賴,是一個危險的標志,因為很有可能這個類完成了超過一件事,違背了單一職責原則。
constructor注入