什么是DI,什么是IoC?
Spring是Java Web开发的一个重要的框架,它在web世界里面无孔不入(除非使用EJB或者原生一点的Servlet),而这个几乎是一统江湖的框架里面,它的根基却基于一个较为简单的东西,这就是IoC。
IoC(Inversion of Control),它的中文意思是控制反转,包含了两个部分,一个是控制,另外一个是反转。控制,指的是由谁去初始化一个对象,例如在一个晚会当中,需要演员去演出,那么演员的创建就是控制,如果是按照面向过程的思路来进行编程,那么我们会做的是直接在晚会的现场直接创建出演员,方便是方便,但是这样会面临一个问题,就是直接创建的演员,那么我就直接就指定了某个演员来演出了,那如果这个演员在晚会的当天病了,那按照这种方式创建的演员就更换不了。幸好我们还有第二个选择,那就是反转,反转的意思就是将创建对象的控制权由晚会移除,交给导演去选择,那么即使有一个演员病了,在导演的英明指导之下,我们也能够替换一个演员,让另外一个演员去演出节目,保证晚会的如期进行。表现在程序上,就是本来在一个方法里面new一个对象,变成了一个入参。
它还有另外一个别名是DI(Dependency Injection)依赖注入。依赖注入由两个部分组成,第一部分是依赖,第二部分是注入。首先说第一部分,依赖。何为依赖?依赖就是一种需求的关系,某个事物只有在另外一个事物存在的时候才存在,某件事情必须要有人支持的时候才能完成。例如一个晚会活动的开展,需要有演员的演出才能做好,那么晚会就依赖了演员。第二部分是注入,注入是一个动词,意思是灌入,表示流体进入容器的过程,当然这里做了引申,不一定是流体,其他的任何东西也是可以的。再举晚会的例子,演员怎么入场,这个就是一个注入的过程。意思还是一样,由一个new对象变成一个入参对象。
IoC包含什么?
IoC包含三种方式,分别是:
- 构造器注入
- setter注入
- 接口注入
既然都已经知道IoC的核心概念是new对象变成入参,那么这三种方式就是不同的入参方法,构造器是指在对象的构造器里面入参,setter注入就是在setter方法中入参,接口注入就是在接口声明方法的时候对方法进行入参,具体的由实现类去处理。相关的示例网上有许多,在这里就不做演示。
为什么要使用IoC?有什么好处?
实质上,在选择任何的一个技术的时候,都会出现一个大乱斗的场面,各个代表各执一词,一方说他们简单好用,另外一方说他复杂但是功能全。在这个选择上面,还是要充分发挥实事求是的精神(这想法真的很牛逼,不要排斥),按照我们实际的场景去进行技术选型。
那么使用IoC的好处有以下几个:
解耦。从开始学编程的时候,都经常会讲到一个词,就是我们写程序需要高内聚、低耦合,但是在实际的开发过程,我们却不停地使用面向过程的开发思路去开发,造成的是低内聚、高耦合,什么低内聚?就是方法很散,方法做的东西不明确,不简短精悍。高耦合是方法和方法之间循环调用,不停new对象。而Spring,连new都不用写了,直接Autowired引入相关的对象,这就降低了耦合程度。
可扩展性。所有的程序都是基于接口的,引用的业务对象使用的是IoC容器内的对象,如果业务有变更,那只需要在接口入参的时候变更内容或者注入其他的业务对象,扩展性大大增强。
更好的可测试性。如果所有的东西都糅合在一起,如果使用A需要引用B,使用B需要引用C,那么我们为了测试这个业务,那需要new C导入到B,然后new B导入到A,然后才能测试A的业务。但是换一个角度,A,B,C都是IoC容器里面有的,那么我只需要Autowired就可以导入相关的依赖,完全不用new一堆对象了。
可重用性。CV程序员复制黏贴代码,使用Spring一个导入对象,就可以使用这个对象的代码,重用代码就是减少代码的复制黏贴。
Spring IoC是什么?
简单来说是一个容器,里面创建了我们所需要的对象,我们在使用对象的时候,就不需要一个个new对象了,当然,除了这个new对象之外,还有的是这些对象之间关系的初始化。这两个作用,专业的说法是业务对象的构建管理和业务对象之间的依赖绑定。
IoC除了有Spring的,还有PicoContainer、Avalon、Google Guice,一下对他们进行简单的介绍:
PicoContainer:一个“微核心 ”(micro-kernel)的容器。它利用了Inversion of Control模式和Template Method模式,提供面向组件的开发、运行环境。PicoContainer是“极小”的容器,只提供了最基本的特性。到目前为止,PicoContainer 最重要的特征是它的尺寸。它没有提供许多附加物,但它具有完整的依赖注入容器。
Avalon:一个包括核心框架、工具、组件和容器的面向组件编程(COP)的完整开发平台。通过使用关键设计模式,如反向控制模式(IoC)和分离考虑模式(SoC)。
Guice:Google公司开发的轻量级IoC容器,其特点是: 速度快,据说是Spring的100倍速度 ;无需配置文件,实用JDK5.0的annotation描述组件依赖,简单,而且有编译器检查和重构支持;简单,代码量很少。
相关的比较就不在这里比较了,因为业内都是使用Spring的,文档多,社区活跃,找问题也方便,而且使用量那么大,相关的性能,公用性之类都会好很多,只需要记住一点就可以了:只用Spring。
怎么使用Spring IoC?
JavaConfig、XML、注解,相关的教程在网上有许多,在这里就不描述了。
SpringIoC的使用,都集中在BeanFactory和ApplicationContext两个类上面,所以,接下来,就是解析这两个类,开始破解Spring的秘密。