php工厂方法模式:1、工厂方法就是为配一个产品提供一个独立的工厂类,通过不同的工厂实例来创建不同的产品实例;2、拥有良好的封装性,代码结构清晰,拥有良好的扩展性,屏蔽产品类。
创新互联建站专业为企业提供南涧网站建设、南涧做网站、南涧网站设计、南涧网站制作等企业网站建设、网页设计与制作、南涧企业网站模板建站服务,10余年南涧做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
php工厂方法模式:
一、 什么是工厂方法模式
工厂方法就是为配一个产品提供一个独立的工厂类,通过不同的工厂实例来创建不同的产品实例。
二、 工厂方法模式的优点
拥有良好的封装性,代码结构清晰。对于每一个对象的创建都是有条件约束的。如:调用一个具体的产品对象,只需要知道这个产品的类名和约束参数就可以了,不用知道创建对象自身的复杂过程。降低模块之间的耦合度。
拥有良好的扩展性,新增一个产品类,只需要适当的增加工厂类或者扩展一个工厂类,如下面的例子中,当需要增加一个数据库Oracle的操作,则只需要增加一个Oracle类,工厂类不用修改任务就可完成系统扩展。
屏蔽产品类。这一特点非常重要,产品类的实现如何变化,调用者都不需要关心,它只需要关心产品的接口,只要接口保持不变,系统中的上层模块就不要发生变化。
三、使用场景
支付宝、微信、银联的连接方式(connectMode),支付方式(payMode)。 使用工厂模式,“客户”就不需要要知道具体的连接方式和支付方式了, 只需要调用connectMode 和 payMode即可。
MySQL
、SQL Server
、Oracle
等数据库的连接方式(connectMode)、查询方式(selectMode)等操作可以使用工厂模式进行封装。
接下来看具体的案例:
产品类:
//抽象产品类 abstract class DataBase { abstract function connect(); abstract function getOne(); } //具体产品类 class MySql extends DataBase { function connect() { return "MySQL连接对象返回"; } function getOne() { return "MySQL返回查询结果"; } } //具体产品类 class SqlServer extends DataBase { function connect() { return "SQL Server连接对象返回"; } function getOne() { return "SQL Server返回查询结果"; } }
工厂类:
//抽象工厂类 abstract class FactoryDataBase{ function createDataBase(){} } //具体工厂类 class FactoryMySql extends FactoryDataBase { public function createDataBase() { return new MySql(); } } //具体工厂类 class FactorySqlServer extends FactoryDataBase { public function createDataBase() { return new SqlServer(); } }
客户:
$mysql = new FactoryMySql(); $db1 = $mysql->createDataBase();
四、工厂方法模式的组成
抽象工厂角色:这是工厂方法模式的核心,它与应用程序无关。是具体工厂角色必须实现的接口或者必须继承的父类。
具体工厂角色:它含有和具体业务逻辑有关的代码。由应用程序调用以创建对应的具体产品的对象。
抽象产品角色:它是具体产品继承的父类或者是实现的接口。
具体产品角色:具体工厂角色所创建的对象就是此角色的实例。
工厂方法模式仿佛已经把对象的创建进行了很完美的包装,使得客户程序中仅仅处理抽象产品角色提供的接口。那我们是否一定要在代码中遍布工厂呢?大可不必。也许在下面情况下你可以考虑使用工厂方法模式:
当客户程序不需要知道要使用对象的创建过程。
客户程序使用的对象存在变动的可能,或者根本就不知道使用哪一个具体的对象。
网站名称:php工厂方法模式问题
标题网址:https://www.cdcxhl.com/article20/cpjjjo.html
成都网站建设公司_创新互联,为您提供企业网站制作、App设计、网站维护、电子商务、定制网站、网页设计公司
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联