php设计模式-依赖注入模式(Dependency Injection)
依赖注入模式用来减少程序间的耦合。
当一个类要使用另一个类时,一般的写法如下:
<?php
class Test1
{
public function say()
{
echo 'hello';
}
}
class Test2
{
public $test1;
public function communicate()
{
$this->test1 = new Test1();
$this->test1->say(); // 调用C类中的方法
//Do something else
}
}
$test2 = new Test2();
$test2->communicate();
当在Test2需要使用Test1时,Test2主动实例化了Test1类,很显然Test2类依赖Test1类,如果以后要修改Test1类的类名,必然要对Test2类做相应的修改,这样Test2类就和Test1类紧紧耦合在了一起。
如何降低这两个类之间的耦合行呢?看如下经过改造后的代码:
<?php
class Test1
{
public function say()
{
echo 'hello';
}
}
class Test2
{
public $test1;
public function __construct(Test1 $test1)
{
$this->test1 = $test1;//实例化c类
}
public function communicate()
{
$this->test1->say(); // 调用C类中的方法
//Do something else
}
}
$test1 = new Test1();
$test2 = new Test2($test1);
$test2->communicate();
Test2不再主动实例化Test1类,而是先创建一个Test1的对象,然后将Test1对象注入到Test2中,这种方法中如果Test1类发生改动,Test2类无需做相应的修改。这就是依赖注入模式的一种实现。依赖注入共有三种模式:构造方法注入,setter方法注入和接口注入。上面的例子就是构造方法注入。构造方法注入的弊端是Test2类依赖的类较多,实例化时参数列表会很长,容易发生混乱。
setter方法注入示例如下:
<?php
class Test1
{
public function say()
{
echo 'hello';
}
}
class Test2
{
public $test1;
public function setTest1(Test1 $test1)
{
$this->test1 = $test1;
}
public function communicate()
{
$this->test1->say(); // 调用C类中的方法
//Do something else
}
}
$test1 = new Test1();
$test2 = new Test2();
$test2->setTest1($test1)
$test2->communicate();
这种方式的弊端是当依赖的类增多时,需要很多的set方法。
另一种实现方法,同理只不过是吧construct改成了别的方法中实例化类了
<?php
/**
* 当有了IoC/DI的容器后,a类依赖c实例注入的示例
*/ /**
* Class c
*/
class c
{
public function say()
{
echo 'hello';
}
} /**
* Class a
*/
class a
{
private $c;
public function setC(C $c)
{
$this->c = $c; // 实例化创建C类
} public function sayC()
{
echo $this->c->say(); // 调用C类中的方法
}
} $c = new C();
$a = new a();
$a->setC($c);
$a->sayC();
php设计模式-依赖注入模式(Dependency Injection)的更多相关文章
- PHP程序员如何理解依赖注入容器(dependency injection container)
背景知识 传统的思路是应用程序用到一个Foo类,就会创建Foo类并调用Foo类的方法,假如这个方法内需要一个Bar类,就会创建Bar类并调用Bar类的方法,而这个方法内需要一个Bim类,就会创建Bim ...
- 清晰架构(Clean Architecture)的Go微服务: 依赖注入(Dependency Injection)
在清晰架构(Clean Architecture)中,应用程序的每一层(用例,数据服务和域模型)仅依赖于其他层的接口而不是具体类型. 在运行时,程序容器¹负责创建具体类型并将它们注入到每个函数中,它使 ...
- Srping - bean的依赖注入(Dependency injection)
目录 1 概述 2 两种基本的依赖注入方式 2.1 构造函数方式 2.2Setter方式 3 其他依赖注入功能 3.1 <ref/>标签引用不同范围的bean 3.2 内部bean 3.3 ...
- 控制反转(Inversion of Control,英文缩写为IoC),另外一个名字叫做依赖注入(Dependency Injection,简称DI)
控制反转(Inversion of Control,英文缩写为IoC),另外一个名字叫做依赖注入(Dependency Injection,简称DI),是一个重要的面向对象编程的法则来削减计算机程序的 ...
- Scalaz(16)- Monad:依赖注入-Dependency Injection By Reader Monad
在上一篇讨论里我们简单的介绍了一下Cake Pattern和Reader Monad是如何实现依赖注入的.主要还是从方法上示范了如何用Cake Pattern和Reader在编程过程中解析依赖和注入依 ...
- 一文读懂Asp.net core 依赖注入(Dependency injection)
一.什么是依赖注入 首先在Asp.net core中是支持依赖注入软件设计模式,或者说依赖注入是asp.net core的核心: 依赖注入(DI)和控制反转(IOC)基本是一个意思,因为说起来谁都离不 ...
- 依赖注入(Dependency Injection)
Spring的两个核心内容为控制反转(Ioc)和面向切面(AOP),依赖注入(DI)是控制反转(Ioc)的一种方式. 依赖注入这个词让人望而生畏,现在已经演变成一项复杂的编程技巧 或设计模式理念.但事 ...
- ASPNET5 依赖注入(Dependency Injection)
依赖注入一直是asp.net web框架(Web API,SignalR and MVC)中不可或缺的一部分,但是在以前,这个框架都是各自升级,都有各自的依赖注入实现方式,即使Katana项目想通过O ...
- Sring控制反转(Inversion of Control,Ioc)也被称为依赖注入(Dependency Injection,DI)原理用反射和代理实现
首先我有一个数据访问层接口: public interface StudentDao { void save(Student stu); } 和实现类: 1.mysql实现类 public class ...
随机推荐
- Ext.isEmpty()的使用
说明如下: isEmpty( Object value, Boolean allowEmptyString ) : Boolean 如果传递的值为空,则返回 true,否则返回 false.该值被认为 ...
- DevExpress ChartControl ViewType.Line
源码地址:https://files.cnblogs.com/files/lanyubaicl/ChartControl.Line.7z public partial class Form1 : Fo ...
- osx安装sass
1.安装ruby (1)OS X 缺少的套件管理工具 homebrew 的安装 http://brew.sh/index_zh-tw.html (2)通过homebrew安装ruby // 到文件夹 ...
- vue-cli中安装方法
源:http://www.cnblogs.com/jn1223/p/6656956.html vue-cli中安装方法 vue-cli脚手架模板是基于node下的npm来完成安装的所以首先需要安装 ...
- 51NOD 1185 威佐夫游戏 V2(威佐夫博弈)
1185 威佐夫游戏 V2 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 有2堆石子.A B两个人轮流拿,A先拿.每次可以从一堆中取任意个或从2堆中取 ...
- Play 2D games on Pixel running Android Nougat (N7.1.2) with Daydream View VR headset
- codeforces 2B The least round way(DP+数学)
The least round way 题目链接:http://codeforces.com/contest/2/problem/B ——每天在线,欢迎留言谈论.PS.本题有什么想法.建议.疑问 欢迎 ...
- Hibernate:查询
本文内容 OID查询 对象导航查询 HQL查询 QBC查询 SQL查询 首发日期:2018-07-31 hibernate的查询方式: hibernate有很多查询方式 OID查询 对象导航查询: H ...
- MySQL状态变量Aborted_connects与Aborted_clients浅析
关于MySQL的状态变量Aborted_clients & Aborted_connects分别代表的意义,以及哪些情况或因素会导致这些状态变量变化呢?下文通过实验测试来验证一下,首先我们来看 ...
- distribution 分发数据库 灾难恢复 备份恢复
参考: http://www.sqlservercentral.com/articles/Replication/117265/ 前提: 准备一台电脑,主机名和以前的分发数据库一致.并且安装s ...