扩大
缩小
  

理解:控制反转IOC和依赖注入DI

一、控制反转(Ioc—Inversion of Control):

不是什么技术,这是一种设计思想。在实际开发中,Ioc意味着将你设计好的对象交给容器控制,而不是传统的在你的对象内部直接控制。
 
技术点1:谁控制谁,控制什么?
在对象内部通过New的方式创建对象实例,这是主动去创建依赖对象;
而IOC是有专门的容易来创建这些对象,即是由IOC容器去控制对象的创建。
那谁控制了谁?当然是IOC容器控制了对象
控制了什么?主要控制了这些外部资源获取
技术点2:为何是反转?(有反转就应该有正转了),哪些方面反转了?
正转:传统应用程序是由我们自己在对象中主动控制去直接获取依赖对象
反转:由容器来帮忙创建及注入依赖对象,为什么是反转?因为由容器帮我们查找和注入依赖对象,对象只是被动的接受依赖对象,所以是反转
 
正转示例图:
反转示例图:
 
 
IOC可以做什么?
  IOC 不是一种技术,只是一种思想,一个重要的面向对象编程的法则,它能指导我们如何设计出松耦合、更优良的程序。传统应用程序都是由我们在类内部主动创建依赖对象,从而导致类与类之间高耦合,难于测试;有了IoC容器后,把创建和查找依赖对象的控制权交给了容器,由容器进行注入组合对象,所以对象与对象之间是 松散耦合,这样也方便测试,利于功能复用,更重要的是使得程序的整个体系结构变得非常灵活。
  其实IoC对编程带来的最大改变不是从代码上,而是从思想上,发生了“主从换位”的变化。应用程序原本是老大,要获取什么资源都是主动出击,但是在IoC/DI思想中,应用程序就变成被动的了,被动的等待IoC容器来创建并注入它所需要的资源了。
  IoC很好的体现了面向对象设计法则之一 好莱坞法则:“别找我们,我们找你”;即由IoC容器帮对象找相应的依赖对象并注入,而不是由对象主动去找。
 

二、依赖注入(Dependency Injection)

依赖注入定义:组件之间依赖关系由容器在运行期决定,形象的说,即由容器动态的将某个依赖关系注入到组件之中。依赖注入的目的并非为软件系统带来更多功能,而是为了提升组件重用的频率,并为系统搭建一个灵活、可扩展的平台。通过依赖注入机制,我们只需要通过简单的配置,而无需任何代码就可指定目标需要的资源,完成自身的业务逻辑,而不需要关心具体的资源来自何处,由谁实现。
 
通俗讲解:
IOC框架的一个重点是在系统运行中,动态的向的某个对象提供它所需要的其他对象。这一点是通过DI来实现的。比如对象A需要操作数据库,以前我们总是要在A中通过代码去获得Connection对象,有了IOC之后我们只需要告诉IOC框架,A中需要一个Connecton,至于这个Connection怎么构造,何时构造,A不需要知道。在系统运行时,IOC框架会在适当的时候制造一个Connection,然后像打针一样,注射到A当中,这样就完成了对各个对象之间关系的控制。A需要依赖Connectio才能正常允许,而这个Connection是由IOC框架注入到A当中的。DI的名字就这么来的,那么A是如何实现的呢?JAVA或者C#允许程序在允许的时候动态生成对象,执行对象的方法,改变对象的熟悉,IOC框架就是通过反射去实现注入的。
 
技术点1:谁依赖谁?
应用程序依赖于IOC容器;
技术点2:为什么需要依赖?
应用程序需要IOC容器来提供对象需要的外部资源;
技术点3:谁注入了谁?
很明显是IOC容器注入应用程序某个对象,应用程序依赖的对象;
技术点4:注入了什么?
注入某个对象所需要的外部资源(包括对象、资源、常量数据)。
 
IOC和DI是什么关系呢?
其实它们是同一个概念的不同角度的描述,由于IOC控制反转的概念比较含糊(可能只是理解为容器控制对象这一个层面,很难让人想到谁来维护对象关系),所以2004年大师级人物Martin Fowler又给出了一个新的名字:“依赖注入”,相对IoC 而言,“依赖注入”明确描述了“被注入的对象,是需要依赖IoC容器去配置依赖对象”。

三、对IOC和DI的个人理解:

如果没有使用IOC和DI,使用的合作对象都要用像new object()的语法来创建,这个合作对象是自己创建出来的,主动权在自己手上,自己需要哪个合作对象,就主动去创建,主动权和创建时机是由自己把控的。这样就使得对象间的耦合度高了。比如A对象需要合作对象B来共同完成一件事,A要使用B,那么A对B就产生了依赖,A和B之间存在一种耦合关系,并且是紧密耦合在一起。
使用依赖注入就不一样了,创建合作对象B的工作由IOC容器来完成,创建好B对象,然后存储在一个容器里面,当A对象需要使用B对象的时候,IOC容器就从容器里面去除A需要使用的那个B对象,然后交给A去使用。至于IOC容器是如何创建,什么时候创建对象的,A对象不需要关注这些细节问题。
 
IOC控制反转理解:是说创建对象的控制权进行转移,以前创建对象的主动权和世界是由自己把控,而现在这种权力转移到第三方,比如转移交给了IOC容器,就是一个专门创建对象的工厂,需要什么对象,他就给你什么对象,有了IOC容器,依赖关系就变了,原来的依赖关系就没了,他们都依赖IOC容器了,通过IOC容器来建立它们之间的关系。
DI依赖注入理解:其实是IOC的另外一种说法,控制的什么被反转了?其实就是获得依赖对象的方式反转了。

posted @ 2020-10-30 14:15  风筝遇上风  阅读(176)  评论(0编辑  收藏  举报