PHP设计模式之适配器模式

目标:
可将一个类的接口转换成客户希望的另外一个接口,使得原本不兼容的接口能够一起工作。通俗的理解就是将不同接口适配成统一的API接口。
角色:

  • Target适配目标,该角色定义把其他类转换为何种接口,也就是我们的期望接口。
  • Adaptee被适配者,就是需要被适配的接口。
  • Adapter适配器,其他的两个角色都是已经存在的角色,而适配器角色是需要新建立的,它用来对Adaptee与Target接口进行适配。

应用场景:
如数据操作有mysql、mysqli、pdo、sqlite、postgresql等,假若生成环境需要更换数据库时,可利用适配器模式统一接口。同理cache的场景也是,这会是更换缓存策略(memcache、redis、apc)更方便。
优势:
被适配者通过适配器完成对适配目标的适配,以达到对客户使用透明的目的。
示例代码:

  
  
  1. //适配目标,规定的接口将被适配对象实现
  2. interface IDatabase
  3. {
  4. public function connect($host, $username, $password, $database);
  5. public function query($sql);
  6. }
  7.  
  8. //适配器
  9. class Mysql implements IDatabase
  10. {
  11. protected $connect;
  12.  
  13. public function connect($host, $username, $password, $database)
  14. {
  15. $connect = mysql_connect($host, $username, $password);
  16. mysql_select_db($database, $connect);
  17. $this->connect = $connect;
  18. //...
  19. }
  20.  
  21. public function query($sql)
  22. {
  23. //...
  24. }
  25. }
  26.  
  27. //适配器
  28. class Postgresql implements IDatabase
  29. {
  30. protected $connect;
  31.  
  32. public function connect($host, $username, $password, $database)
  33. {
  34. $this->connect = pg_connect("host=$host dbname=$database user=$username password=$password");
  35. //...
  36. }
  37.  
  38. public function query($sql)
  39. {
  40. //...
  41. }
  42. }
  43.  
  44.  
  45. //客户端使用
  46. $client = new Postgresql();
  47. $client->query($sql);

如上:
  • Target适配目标: IDataBase接口
  • Adaptee被适配者: mysql和postgresql的数据库操作函数
  • Adapter适配器 :mysql类和postgresql类
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值