Rumah >php教程 >php手册 >PHP设计模式之适配器模式代码实例

PHP设计模式之适配器模式代码实例

WBOY
WBOYasal
2016-06-13 09:04:531174semak imbas

PHP设计模式之适配器模式代码实例

   这篇文章主要介绍了PHP设计模式之适配器模式代码实例,本文讲解了目标、角色、应用场景、优势等内容,并给出代码实例,需要的朋友可以参考下

  目标:

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

  角色:

  Target适配目标,该角色定义把其他类转换为何种接口,也就是我们的期望接口。

  Adaptee被适配者,就是需要被适配的接口。

  Adapter适配器,其他的两个角色都是已经存在的角色,而适配器角色是需要新建立的,它用来对Adaptee与Target接口进行适配。

  应用场景:

  如数据操作有mysql、mysqli、pdo、sqlite、postgresql等,假若生成环境需要更换数据库时,可利用适配器模式统一接口。同理cache的场景也是,这会是更换缓存策略(memcache、redis、apc)更方便。

  优势:

  被适配者通过适配器完成对适配目标的适配,以达到对客户使用透明的目的。

  示例代码:

  ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

//适配目标,规定的接口将被适配对象实现

interface IDatabase

{

public function connect($host, $username, $password, $database);

public function query($sql);

}

 

//适配器

class Mysql implements IDatabase

{

protected $connect;

 

public function connect($host, $username, $password, $database)

{

$connect = mysql_connect($host, $username, $password);

mysql_select_db($database, $connect);

$this->connect = $connect;

//...

}

 

public function query($sql)

{

//...

}

}

 

//适配器

class Postgresql implements IDatabase

{

protected $connect;

 

public function connect($host, $username, $password, $database)

{

$this->connect = pg_connect("host=$host dbname=$database user=$username password=$password");

//...

}

 

public function query($sql)

{

//...

}

}

 

 

//客户端使用

$client = new Postgresql();

$client->query($sql);

  如上:

  Target适配目标: IDataBase接口

  Adaptee被适配者: mysql和postgresql的数据库操作函数

  Adapter适配器 :mysql类和postgresql类

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn