一、IOC是什么,能做什么
IOC不是一种技术,只是一种思想,一个重要的面向对象的法则,它能指导我们如何设计出松耦合,更优良的程序。传统应用程序都是由我们在类内部主动创建依赖对象,从而导致类与类之间高耦合,难于测试;但是有了IOC容器后,把创建和查找依赖对象的控制权交给了容器,由容器进行注入组合对象,所以对象与对象之间是松散耦合,这样也方便测试,利于功能复用,更重要的是使得程序的整个体系结构变得非常灵活。
其实IOC对编程编程带来的最大改变不是从代码上,而是从思想上,发生了“主从换位”的变化。应用程序原来是主,要获取哪一个资源都是主动出击,但是在IOC/DI思想中,应用程序就变得被动了,被动的等待IOC容器来创建并注入它所需的资源了。
IOC很好的体现了面向对象的设计法则,IOC容器帮对象找相应的依赖对象并注入,而不再是对象主动寻找。
二、IOC和DI
DI(Dependency Injection)即“依赖注入”:组件之间依赖的关系由容器在运行期决定,形象的说,即由容器动态的将某个依赖关系注入到组件之中,依赖注入的目的并非为软件系统带来更对功能,而是为了提升组件重用的频率,并未系统搭建一个灵活、可扩展的平台。通过依赖注入机制,我们只需要通过简单的配置,而无需任何代码就可以指定目标需要的资源,完成自身的业务逻辑,而不需要关系具体的资源由谁提供。
理解DI的关键是:谁依赖谁,为什么需要注入,注入了什么:
谁依赖谁:是应用程序依赖于IOC容器
为什么需要依赖:应用程序需要IOC容器来提供对象需要的外部资源
谁注入到谁:IOC容器注入应用程序某个对象,应用程序依赖的对象
注入了什么:注入了某个对象所需要的外部资源(包括对象、资源、常量数据等)
三、IOC和DI有什么关系
IOC和DI其实它们是同一个概念的不同角度描述,由于控制翻转概念比较含糊,(我的理解可能只是为容器控制对象这一层面),相对IOC,DI明确描述了被注入对象依赖IOC容器配置依赖对象
四、IOC(个人理解)
在Java应用开发中,我么要实现一个功能或者说需要业务逻辑时,至少需要两个以上的对象来协作完成。在没有Spring的时候,我们用传统的方式new出两个对象或者多个对象,然而这样的创建对象的方式耦合度高,比如对象A和对象B被创建,若使用两个对象,这两个对选哪个就有很强的依赖关系,紧密耦合在一起。
而使用了Spring之后就有所不同了,创建对象A和B对象时,都交由Spring去创建,创建后,然后存储到一个容器里面,当A对象需要使用B对象时,Spring就从存放对象的那个容器里面取出A要使用的对象B,然后交给对象B去使用,至于Spring是如何创建那个对象,以及什么时候取出,A对象就不需要知道这些问题了,这其实就是Java面向对象中的封装特性。控制反转还有一个漂亮的比喻:好莱坞原则(Hollywood principle),"不要打电话给我们,我们会打给你(如果合适)" ("don't call us, we'll call you." ),这是好莱坞电影公司对面试者常见的答复.
所以控制翻转是说创建对象的控制权进行了转移,这样,有了IOC容器,依赖关系就变了,耦合性降低。其实最终就是依赖对象的方式翻转了。