使用IntelliJ IDEA進行開發的時候,code analyze的時候會出現提示“Field injection is not recommended”。
stackoverflow上有篇回答:http://stackoverflow.com/questions/39890849/what-exactly-is-field-injection-and-how-to-avoid-it
國外有篇文章:http://vojtechruzicka.com/field-dependency-injection-considered-harmful/
spring官方文檔:http://docs.spring.io/spring/docs/4.2.x/spring-framework-reference/html/beans.html
依賴注入方式:
1、通過構造方法
2、通過setters或者其它方法
3、通過反射直接注入到fields
一般的@Autowired就是通過第三種方式
注入的指導方針:
1、為了強制依賴,或者為了易變性,使用構造方法注入
2、為了可選的或者可變的依賴,使用setter注入
3、盡量避免使用直接在屬性上注入
屬性注入的壞處:
1、你不能使用屬性注入的方式構建不可變對象。
2、你的類和依賴容器強耦合,不能再容器外使用。
3、你的類不能繞過反射(例如單元測試的時候)進行實例化,必須通過依賴容器才能實例化,這更像是集成測試。
4、實際的依賴被隱藏在外面,不是在構造方法或者其它方法里面反射的。
5、一個類經常會有超過10個的依賴。如果使用構造方法的方式注入的話,構造方法會有10個參數,明顯有點蠢。但是如果使用屬性注入的話就沒有這樣的限制。但是一個類有很多的依賴,是一個危險的標志,因為很有可能這個類完成了超過一件事,違背了單一職責原則。
總結:
盡量避免使用屬性注入,雖然非常方便。