跳转到内容

控制反转:修订间差异

维基百科,自由的百科全书
删除的内容 添加的内容
JeffreyZhang722留言 | 贡献
InternetArchiveBot留言 | 贡献
补救1个来源,并将0个来源标记为失效。 #IABot (v1.4)
第53行: 第53行:
}}
}}
#{{note_label|Martin 2005|Martin 2005|none}} {{cite web
#{{note_label|Martin 2005|Martin 2005|none}} {{cite web
| author = Robert Cecil Martin
|author=Robert Cecil Martin
| url= http://www.objectmentor.com/resources/articles/dip.pdf
|url=http://www.objectmentor.com/resources/articles/dip.pdf
| title = The Dependency Inversion Principle
|title=The Dependency Inversion Principle
| format = PDF
|format=PDF
| accessdate = 2005-11-15
|accessdate=2005-11-15
|deadurl=yes
|archiveurl=https://web.archive.org/web/20041221102842/http://www.objectmentor.com/resources/articles/dip.pdf
|archivedate=2004-12-21
}}
}}
#{{note_label|Fowler 2004|Fowler 2004|none}} {{cite web
#{{note_label|Fowler 2004|Fowler 2004|none}} {{cite web

2017年7月3日 (一) 09:03的版本

控制反转(Inversion of Control,缩写为IoC),是面向对象编程中的一种设计原则,可以用来减低计算机代码之间的耦合度。其中最常见的方式叫做依赖注入(Dependency Injection,简称DI),还有一种方式叫“依赖查找”(Dependency Lookup)。通过控制反转,对象在被创建的时候,由一个调控系统内所有对象的外界实体,将其所依赖的对象的引用传递给它。也可以说,依赖被注入到对象中。

起源

早在2004年,Martin Fowler就提出了“哪些方面的控制被反转了?”这个问题。他总结出是依赖对象的获得被反转了,因为大多数应用程序都是由两个或是更多的类通过彼此的合作来实现企業逻辑,这使得每个对象都需要获取与其合作的对象(也就是它所依赖的对象)的引用。如果这个获取过程要靠自身实现,那么这将导致代码高度耦合并且难以维护和调试。

技术描述

Class A中用到了Class B的对象b,一般情况下,需要在A的代码中显式的new一个B的对象。

采用依赖注入技术之后,A的代码只需要定义一个私有的B对象,不需要直接new来获得这个对象,而是通过相关的容器控制程序来将B对象在外部new出来并注入到A类里的引用中。而具体获取的方法、对象被获取时的状态由配置文件(如XML)来指定。

实现方法

实现控制反转主要有两种方式:依赖注入和依赖查找。两者的区别在于,前者是被动的接收对象,在类A的实例创建过程中即创建了依赖的B对象,通过类型或名称来判断将不同的对象注入到不同的属性中,而后者是主动索取相应类型的对象,获得依赖对象的时间也可以在代码中自由控制。

依赖注入

依赖注入有如下实现方式:

  • 基于接口。实现特定接口以供外部容器注入所依赖类型的对象。
  • 基于 set 方法。实现特定属性的public set方法,来让外部容器调用传入所依赖类型的对象。
  • 基於构造函数。实现特定参数的构造函数,在新建对象时传入所依赖类型的对象。
  • 基于注解。基于Java的注解功能,在私有变量前加“@Autowired”等注解,不需要显式的定义以上三种代码,便可以让外部容器传入对应的对象。该方案相当于定义了public的set方法,但是因为没有真正的set方法,从而不会为了实现依赖注入导致暴露了不该暴露的接口(因为set方法只想让容器访问来注入而并不希望其他依赖此类的对象访问)。

依赖查找

依赖查找更加主动,在需要的时候通过调用框架提供的方法来获取对象,获取时需要提供相关的配置文件路径、key等信息来确定获取对象的状态

控制反转应用实例

C++

  • PocoCapsule IoC and DSM framework LGPL开源的,支持完全非侵入C++的控制反转(IoC)及领域特定建模(DSM)容器
  • hypodermic MIT开源协议,Hypodermic是一个基于C++11开发的控制反转(IoC)容器,它为你的C++对象协作提供依赖注入。Hypodermic灵感来自著名的.NET IoC项目Autofac。

Java

使用Java語言寫成的程式在控制反轉容器(Inversion of Control Container)裡應用了控制反轉(Martin 2004)。軟體需要一個來自容器的物件,而容器自行建構物件和它的附屬物。ATGDynamo 應用程式伺服器是第一個利用這途徑的環境之一,近來關於這些容器的例子包含了 HiveMindPicoContainerSpring Framework(注意 Spring 是一個完整的企業平台,而非 IOC容器)、Apache ExcaliburSeasarDPML Metro.

.NET

PHP

参考文档

  1. ^ Robert Cecil Martin. Agile Software Development: Principles, Patterns and Practices. Pearson Education. 2002. ISBN 978-0-13-597444-5. 
  2. ^ Robert Cecil Martin. The Dependency Inversion Principle (PDF). [2005-11-15]. (原始内容 (PDF)存档于2004-12-21). 
  3. ^ Martin Fowler. Inversion of Control Containers and the Dependency Injection Pattern. 2004 [2005-11-15]. 
  4. ^ Sony Mathew. Examining the Validity of Inversion of Control. 2005 [2005-11-16]. 
  5. ^ Ke Jin. Domain Specific Modeling (DSM) in IoC frameworks. 2007 [2007-11-13]. 

外部链接

參考文獻