依赖注入
-
传统的思路
应用程序用到一个Foo类,就会创建Foo类并调用Foo类的方法。 假如这个方法内需要一个Bar类,就会创建Bar类并调用Bar类的方法。 而这个方法内需要一个Bim类,就会创建Bim类,接着做些其它工作。
/**
* Foo
*/
class Foo
{
public function doSomething($value='')
{
# code...
$Bar = new Bar();
$Bar->doSomething();
echo 'Foo doSomething','<br />' ;
}
}
/**
* Bar
*/
class Bar
{
public function doSomething($value='')
{
# code...
$Bim = new Bim();
$Bim->doSomething();
echo 'Bar doSomething','<br />' ;
}
}
/**
* Bim
*/
class Bim
{
public function doSomething($value='')
{
# code...
echo 'Bim doSomething','<br />' ;
}
}
$doSomething = new Foo();
$doSomething->doSomething();
- 依赖注入
应用程序用到Foo类,Foo类需要Bar类,
Bar类需要Bim类,那么先创建Bim类,再创建Bar类并把Bim注入,再创建Foo类,并把Bar类注入,
再调用Foo方法,Foo调用Bar方法,接着做些其它工作。
/**
* Bim2
*/
class Bim2
{
public function doSomething($value='')
{
# code...
echo 'Bim2 doSomething','<br />' ;
}
}
/**
* Bar2
*/
class Bar2
{
private $bim2 ;
public function __construct(Bim2 $bim2)
{
# code...
$this->bim2 = $bim2 ;
}
public function doSomething($value='')
{
# code...
$this->bim2->doSomething();
echo "Bar2 doSomething",'<br />';
}
}
/**
* Foo
*/
class Foo2
{
private $bar2 ;
public function __construct(Bar2 $bar2)
{
# code...
$this->bar2 = $bar2 ;
}
public function doSomething($value='')
{
# code...
$this->bar2->doSomething();
echo "Foo2 doSomething",'<br />';
}
}
$doSomething2 = new Foo2(new Bar2(new Bim2()));
$doSomething2->doSomething();
这就是控制反转模式。依赖关系的控制反转到调用链的起点。这样你可以完全控制依赖关系,通过调整不同的注入对象,来控制程序的行为。
例如Foo类用到了memcache,可以在不修改Foo类代码的情况下,改用redis。
使用依赖注入容器后的思路是应用程序需要到Foo类,就从容器内取得Foo类,容器创建Bim类,再创建Bar类并把Bim注入,再创建Foo类,并把Bar注入,应用程序调用Foo方法,Foo调用Bar方法,接着做些其它工作.
扩展:容器负责实例化,注入依赖,处理依赖关系等工作。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。