适配器模式核心思想:把对某些相似的类的操作转化为一个统一的“接口”(这里是比喻的说话)--适配器,或者比喻为一个“界面”,统一或屏蔽了那些类的细节。适配器模式还构造了一种“机制”,使“适配”的类可以很容易的增减,而不用修改与适配器交互的代码,符合“减少代码间耦合”的设计原则。
? 以下示例,用接近伪码的 php 语法,演示了一个数据库操作的适配器类,它可以操作 mysql 和 oracle 数据库,但使用了相同的方法。由于使用了适配器(adapter)模式,我们不必关心 mysql 和 oracle 数据库操作类的不同。
? 我们还可以方便的添加进 sqlite 等数据库操作的类,“插入”适配器中,立即就可以用操作 mysql 和 oracle 相同的方法来操作 sqlite 数据库了。
? //适配器类:
? //定义了4个操作所有数据库的方法
db = $db_obj; } function select_record() { $this->db->select (); } function insert_record() { $this->db->insert (); } function update_record() { $this->db->update (); } function delete_record() { $this->db->delete (); }}//mysql 数据库操作类:class mysql { private $obj_mysql; function __construct() { $obj_mysql = ...... ; } function select() { $obj_mysql->mysql_select (); } function insert() { $obj_mysql->mysql_insert (); } function update() { $obj_mysql->mysql_update (); } function delete() { $obj_mysql->mysql_delete (); }}//oracle 数据库操作类:class oracle { private $obj_oracle; function __construct() { $obj_oracle = ...... ; } function select() { $obj_oracle->oracle_select (); } function insert() { $obj_oracle->oracle_insert (); } function update() { $obj_oracle->oracle_update (); } function delete() { $obj_oracle->oracle_delete (); }} //操作 mysql 数据库: $obj = new db_adapter(new mysql()) $obj->select_record (); $obj->insert_record (); $obj->update_record (); $obj->delete_record (); //操作 oracle 数据库: $obj = new db_adapter(new oracle()) $obj->select_record (); $obj->insert_record (); $obj->update_record (); $obj->delete_record ();?>
要求:mysql、oracle 类,有相同名字、相同个数的方法。方法内部实现了各自的操作数据库的代码。转换就是在这里完成的。
? 增加新的数据库操作:构造新的类,有相同名字、相同个数的方法。方法内部实现不被关心(被屏蔽) - 不同的数据库实现不同。
? 小缺点:新的类,可能因为疏忽,导致方法名字不合要求、个数不同。
? 为了减少出错的可能,可以改进一下。方法就是定义一个接口,作为模板来继承,达到规范化。
? db_adapter 类里的方法,只需要使用 interface db_driver 里函数即可。
?
