注解使用的三种方式:
本文参考地址:https://www.cnblogs.com/chansblogs/p/8343930.html 感谢作者
我们在使用依赖注入的时候,通常由三种方式:
1.构造器注入
2. 通过setter方法注入
3. 通过field方式注入
public class MyAutowired { @Autowired private Person persona; @Autowired private Person personb; @Autowired private Person personc; @Autowired public MyAutowired (Person a,Person b,Person c){ persona = a; personb = b; personc = c; } @Autowired public void setPersonA(Person person){ persona = person; } @Autowired public void setPersonB(Person person){ personb = person; } @Autowired public void setPersonC(Person person){ personc = person; }
}
三种方式的区别小结:
1.基于constructor的注入,会固定依赖注入的顺序;该方式不允许我们创建bean对象之间的循环依赖关系,这种限制其实是一种利用构造器来注入的益处 - 当你甚至没有注意到使用setter注入的时候,Spring能解决循环依赖的问题;
2.基于setter的注入,只有当对象是需要被注入的时候它才会帮助我们注入依赖,而不是在初始化的时候就注入;另一方面如果你使用基于constructor注入,CGLIB不能创建一个代理,迫使你使用基于接口的代理或虚拟的无参数构造函数。
3.相信很多同学都选择使用直接在成员变量上写上注解来注入,正如我们所见,这种方式看起来非常好,精短,可读性高,不需要多余的代码,也方便维护;
缺点:
1.当我们利用constructor来注入的时候,比较明显的一个缺点就是:假如我们需要注入的对象特别多的时候,我们的构造器就会显得非常的冗余、不好看,非常影响美观和可读性,维护起来也较为困难;
2.当我们选择setter方法来注入的时候,我们不能将对象设为final的;
3.当我们在field变量上来实现注入的时候
a.这样不符合JavaBean的规范,而且很有可能引起空指针;
b.同时也不能将对象标为final的;
c.类与DI容器高度耦合,我们不能在外部使用它;
d.类不通过反射不能被实例化(例如单元测试中),你需要用DI容器去实例化它,这更像集成测试;
... etc.