學習php設計模式 php實現(xiàn)抽象工廠模式
抽象工廠模式(Abstact Factory)是一種常見的軟件設計模式。該模式為一個產(chǎn)品族提供了統(tǒng)一的創(chuàng)建接口。當需要這個產(chǎn)品族的某一系列的時候,可以為此系列的產(chǎn)品族創(chuàng)建一個具體的工廠類。
一、意圖
抽象工廠模式提供一個創(chuàng)建一系統(tǒng)相關或相互依賴對象的接口,而無需指定它們具體的類【GOF95】
二、抽象工廠模式結構圖
三、抽象工廠模式中主要角色
抽象工廠(Abstract Factory)角色:它聲明一個創(chuàng)建抽象產(chǎn)品對象的接口。通常以接口或抽象類實現(xiàn),所有的具體工廠類必須實現(xiàn)這個接口或繼承這個類。
具體工廠(Concrete Factory)角色:實現(xiàn)創(chuàng)建產(chǎn)品對象的操作。客戶端直接調用這個角色創(chuàng)建產(chǎn)品的實例。這個角色包含有選擇合適的產(chǎn)品對象的邏輯。通常使用具體類實現(xiàn)。
抽象產(chǎn)品(Abstract Product)角色:聲明一類產(chǎn)品的接口。它是工廠方法模式所創(chuàng)建的對象的父類,或它們共同擁有的接口。
具體產(chǎn)品(Concrete Product)角色:實現(xiàn)抽象產(chǎn)品角色所定義的接口,定義一個將被相應的具體工廠創(chuàng)建的產(chǎn)品對象。其內(nèi)部包含了應用程序的業(yè)務邏輯。
四、抽象工廠模式的優(yōu)缺點
抽象工廠模式的優(yōu)點:
1、分離了具體的類
2、使增加或替換產(chǎn)品族變得容易
3、有利于產(chǎn)品的一致性
抽象工廠模式的缺點: 難以支持新種類的產(chǎn)品。這是因為AbstractFactory接口確定了可以被創(chuàng)建的產(chǎn)品集合。支持新各類的產(chǎn)品就需要擴展訪工廠接口,從而導致AbstractFactory類及其所有子類的改變。
抽象工廠就是以一種傾斜的方式支持增加新的產(chǎn)品中,它為新產(chǎn)品族的增加提供了方便,而不能為新的產(chǎn)品等級結構的增加提供這樣的方便。
五、抽象工廠模式適用場景
以下情況應當使用抽象工廠模式:
1、一個系統(tǒng)不應當依賴于產(chǎn)品類實例如何被創(chuàng)建、組合和表達的細節(jié),這對于所有形態(tài)的工廠模式都是重要的。
2、這個系統(tǒng)的產(chǎn)品有多于一個的產(chǎn)品族,而系統(tǒng)只消費其中某一族的產(chǎn)品。
3、 同屬于同一個產(chǎn)品族的產(chǎn)品是在一起使用的,這一約束必須在系統(tǒng)的設計中體現(xiàn)出來。
4、系統(tǒng)提供一個產(chǎn)品類的庫,所有的產(chǎn)品以同樣的接口出現(xiàn),從而使用客戶端不依賴于實現(xiàn)
六、抽象工廠模式與其它模式
單例模式(singleton模式):具體工廠類可以設計成單例類,由于工廠通常有一個就可以,因此具體工廠子類一般都實現(xiàn)為一個Singleton。
工廠方法模式(factory method模式):抽象工廠創(chuàng)建產(chǎn)品的方法定義為工廠方法。
原型模式(prototype模式):如果有多個可能的產(chǎn)品系列,具體的工廠也可以使用原型模式,具體工廠使用產(chǎn)品系列中
每一個產(chǎn)品的原型進行實例化并且通過復制它的原型來創(chuàng)建新的產(chǎn)品。
七、抽象工廠模式PHP示例
<?php /** * 抽象工廠 */ interface AbstractFactory { /** * 創(chuàng)建等級結構為A的產(chǎn)品的工廠方法 */ public function createProductA(); /** * 創(chuàng)建等級結構為B的產(chǎn)品的工廠方法 */ public function createProductB(); } /** * 具體工廠1 */ class ConcreteFactory1 implements AbstractFactory{ public function createProductA() { return new ProductA1(); } public function createProductB() { return new ProductB1(); } } /** * 具體工廠2 */ class ConcreteFactory2 implements AbstractFactory{ public function createProductA() { return new ProductA2(); } public function createProductB() { return new ProductB2(); } } /** * 抽象產(chǎn)品A */ interface AbstractProductA { /** * 取得產(chǎn)品名 */ public function getName(); } /** * 抽象產(chǎn)品B */ interface AbstractProductB { /** * 取得產(chǎn)品名 */ public function getName(); } /** * 具體產(chǎn)品A1 */ class ProductA1 implements AbstractProductA { private $_name; public function __construct() { $this->_name = 'product A1'; } public function getName() { return $this->_name; } } /** * 具體產(chǎn)品A2 */ class ProductA2 implements AbstractProductA { private $_name; public function __construct() { $this->_name = 'product A2'; } public function getName() { return $this->_name; } } /** * 具體產(chǎn)品B1 */ class ProductB1 implements AbstractProductB { private $_name; public function __construct() { $this->_name = 'product B1'; } public function getName() { return $this->_name; } } /** * 具體產(chǎn)品B2 */ class ProductB2 implements AbstractProductB { private $_name; public function __construct() { $this->_name = 'product B2'; } public function getName() { return $this->_name; } } /** * 客戶端 */ class Client { /** * Main program. */ public static function main() { self::run(new ConcreteFactory1()); self::run(new ConcreteFactory2()); } /** * 調用工廠實例生成產(chǎn)品,輸出產(chǎn)品名 * @param $factory AbstractFactory 工廠實例 */ public static function run(AbstractFactory $factory) { $productA = $factory->createProductA(); $productB = $factory->createProductB(); echo $productA->getName(), '<br />'; echo $productB->getName(), '<br />'; } } Client::main(); ?>
以上就是使用php實現(xiàn)抽象工廠模式的代碼,還有一些關于抽象工廠模式的概念區(qū)分,希望對大家的學習有所幫助。
相關文章
淺談ThinkPHP5.0版本和ThinkPHP3.2版本的區(qū)別
小編小編就為大家?guī)硪黄獪\談ThinkPHP5.0版本和ThinkPHP3.2版本的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06