PHP 设计模式(五):适配器模式

什么是适配器模式

将一个类的接口转换成外部希望的另外一个接口,使用原本不兼容的而不能在一起工作的那些类可以在一起工作。适配器就是一个把拥有相似功能但是接口名不同的类封装成拥有同样接口名的类,这样只需要更改接口引入的类,但不需要改变类中的方法,就可以换成另一个相同功能不同类名和方法名。

应用场景

如数据库多种驱动的适配、缓存多种方案的适配、日志存储的适配等。

跟策略模式不要混淆,这是不同的,适配器模式是对每种不同策略的接口做统一,而策略模式是能随需求切换选择不同的策略。

PHP 代码实现
<?php

/**
 * 数据库适配器接口
 * Interface Target
 */
Interface Target{
    public function connect($host, $user, $password, $dbname);
    public function query($sql);
    public function close();
}

/**
 * MySQL 驱动适配
 * Class MySQLAdapter
 */
class MySQLAdapter implements Target
{
    protected $conn;

    public function connect($host, $user, $password, $dbname)
    {
        $conn = mysql_connect($host, $user, $password);
        mysql_select_db($dbname, $conn);
        $this->conn = $conn;
    }

    public function query($sql)
    {
        $res = mysql_query($sql, $this->conn);
        return $res;
    }

    public function close()
    {
        mysql_close($this->conn);
    }
}

/**
 * MySQLi 驱动适配
 * Class MySQLiAdaptee
 */
class MySQLiAdapter
{
    protected $conn;

    public function connect($host, $user, $password, $dbname)
    {
        $conn = mysqli_connect($host, $user, $password, $dbname);
        $this->conn = $conn;
    }

    public function query($sql)
    {
        return mysqli_query($this->conn, $sql);
    }

    public function close()
    {
        mysqli_close($this->conn);
    }
}

/**
 * 用户调用数据库工厂
 * Class DataBase
 */
Class DataBase implements Target {

    /**
     * @var 数据库对象
     */
    protected $db ;

    public function  __construct($type){
        $type = $type . "Adapter" ;
        $this->db = new $type ;
    }

    public function connect($host, $user, $password, $dbname){
        $this->db->connect($host, $user, $password, $dbname);
    }

    public function query($sql){
        return $this->db->query($sql);
    }

    public function close(){
        $this->db->close();
    }
}

//=======================调用适配器===============================

//用户调用同一个接口,使用MySQL和mysqli这两套不同示例。
$db1 = new DataBase('MySQL');
$db1->connect('127.0.0.1','root','root','test');
$db1->query('select * from user');
$db1->close();

$db2 = new DataBase('MySQLi');
$db2->connect('127.0.0.1','root','root','test');
$db2->query('select * from user');
$db2->close();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值