谈谈对Spring控制反转和依赖注入的一些理解
一、什么是控制反转?什么是依赖注入?
当某个Java对象(调用者)需要调用另一个Java对象(被调用者,即被依赖对象)时,在传统模式下,调用者通常会采用 “new 被调用者” 的方式。
在使用Spring框架之后,"new 被调用者"的动作由Spring 容器来完成。Spring容器将被依赖对象赋值给调用者的成员变量,而不是由调用者的程序代码直接控制。Spring的开发者把这个动作叫做“依赖注入”,把这种控制权反转的设计称为“控制反转”。
二、spring依赖注入能解决什么问题?
如上图所示,大型项目中复杂业务往往需要多个类组合完成,A的成员变量包含B1、B2,B1成员变量又包含C1、C2,B2成员变量又包含C3、C4。此时我们使用A类时,需要这样写:
A a = new A(new B1(new C1(), new C2()),new B2(new C3(), new C4()));
可以发现,当我们使用一个类时,必须初始化它的成员变量类、成员变量类的成员变量类、成员变量类的成员变量类的成员变量类……。当类越来越复杂时,类的初始化也越来越复杂。而且我们只想使用某个类的功能,并不关心它的子孙依赖有哪些,这显然是个很严重的问题。
有的人可能会说,我不以成员变量的方式组合类,当在类A中使用类B1、B2时,使用new来初始化后使用。这样做A1每个方法中使用类B1、B2时都要初始化一次,并且如果不是类B1、B2而是接口B1、B2,这样无法快速更换实现类。因此一般不这么组合类。
Spring依赖注入恰恰解决了这个问题。我们知道Spring会为每个标记为bean的类在容器中创建对象,创建对象时Spring会把当前对象及其依赖组装好。这样当我们需要使用类A时,无需初始化,也无需了解它的依赖,直接使用Spring容器中的bean对象即可。并且Spring采用xml配置或者注解方式配置依赖,替代高耦合的使用代码new形式。
综上所述,可以看出Spring的依赖注入主要有以下两个好处:
1、降低程序间的耦合;
2、省去繁琐的依赖关系管理。