适配器模式是php设计模式中的一个常用的模式
发布时间:2023-09-16 14:40:33 所属栏目:PHP教程 来源:
导读:适配器模式是php设计模式中的一个常用的模式了,很多朋友对于这个适配器模式不了解,下面小编和各位介绍一下吧,希望对大家帮助.
适配器模式有什么用?
将一个类的接口转换成客户希望的另外一个接口。适配器模
适配器模式有什么用?
将一个类的接口转换成客户希望的另外一个接口。适配器模
适配器模式是php设计模式中的一个常用的模式了,很多朋友对于这个适配器模式不了解,下面小编和各位介绍一下吧,希望对大家帮助. 适配器模式有什么用? 将一个类的接口转换成客户希望的另外一个接口。适配器模式使得原来由于接口不兼容而不能一起工作的那此类可以一起工作 适用性 1、你想使用一个已经存在的类,而它的接口不符合你的需求 2、你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类协同工作 3、你想使用一个已经存在的子类,但是不可能对每一个都进行子类化以匹配它们的接口。对象适配器可以适配它的父类接口(仅限于对象适配器) 应用举例,例如PHP的数据库操作有MySQL、Mssql、PDO等,可以用适配器模式统一成一致。类似的场景还有cache适配器,将memcache、redis、file、apc等不同的缓存函数,统一成一致。 接下来我们以数据库操作来举例,为了编辑方便,博主就把代码都写一起了 <?php /** * PHP设计模式之适配器模式实例 * */ /** * 目标角色 * 创建一个接口文件 DataBase.php * 定义一个数据库接口 * 声明方法 */ interface IDataBase { public function connect($host, $user, $passwd, $dbname); public function query($sql); public function close(); } /** * 源角色 */ class Adaptee { /** * 源类含有的方法 */ public function connect($host, $user, $passwd, $dbname) { return 'Adaptee'; } } /** * 类适配器角色 * 创建mysql操作类文件 Mysql.php * 继承接口 实现接口方法 */ class Mysql implements IDataBase { private $_adaptee; function __construct() { $this->_adaptee = new Adaptee(); } public function connect($host, $user, $passwd, $dbname){ /** * code... * 委派调用Adaptee的connect方法 */ $this->_adaptee->connect($host, $user, $passwd, $dbname); //return 'ok'; } public function query($sql){ /** * code... */ return 'ok'; } public function close(){ /** * code... */ return 'ok'; } } /** * 类适配器角色 * 创建mssql操作类文件 Mssql.php * 继承接口 实现接口方法 */ class Mssql implements IDataBase { public function connect($host, $user, $passwd, $dbname){ /** * code... */ return 'ok'; } public function query($sql){ /** * code... */ return 'ok'; } public function close(){ /** * code... */ return 'ok'; } } /** * 类适配器角色 * 创建pdo操作类文件 Pdo.php * 继承接口 实现接口方法 */ class Pdfo implements IDataBase { public function connect($host, $user, $passwd, $dbname){ /** * code... */ return 'ok'; } public function query($sql){ /** * code... */ return 'ok'; } public function close(){ /** * code... */ return 'ok'; } } /** * 使用 * 这样就可以任意的在三种适配器之间进行切换 */ $db = new Mysql(); echo $db->connect('127.0.0.1', 'root', 'root', 'test'); echo $db->query('show databases'); echo $db->close(); ?> (编辑:汽车网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐