C++設(shè)計模式之抽象工廠模式
問題描述
之前講到了C++設(shè)計模式——工廠方法模式,我們可能會想到,后期產(chǎn)品會越來越多了,建立的工廠也會越來越多,工廠進(jìn)行了增長,工廠變的凌亂而難于管理;由于工廠方法模式創(chuàng)建的對象都是繼承于Product的,所以工廠方法模式中,每個工廠只能創(chuàng)建單一種類的產(chǎn)品,當(dāng)需要生產(chǎn)一種全新的產(chǎn)品(不繼承自Product)時,發(fā)現(xiàn)工廠方法是心有余而力不足。
舉個例子來說:一個顯示器電路板廠商,旗下的顯示器電路板種類有非液晶的和液晶的;這個時候,廠商建造兩個工廠,工廠A負(fù)責(zé)生產(chǎn)非液晶顯示器電路板,工廠B負(fù)責(zé)生產(chǎn)液晶顯示器電路板;工廠一直就這樣運行著。有一天,總經(jīng)理發(fā)現(xiàn),直接生產(chǎn)顯示器的其余部分也挺掙錢,所以,總經(jīng)理決定,再建立兩個工廠C和D;C負(fù)責(zé)生產(chǎn)非液晶顯示器的其余部件,D負(fù)責(zé)生產(chǎn)液晶顯示器的其余部件。此時,旁邊參謀的人就說了,經(jīng)理,這樣做不好,我們可以直接在工廠A中添加一條負(fù)責(zé)生產(chǎn)非液晶顯示器的其余部件的生產(chǎn)線,在工廠B中添加一條生產(chǎn)液晶顯示器的其余部件的生產(chǎn)線,這樣就可以不用增加廠房,只用將現(xiàn)有廠房進(jìn)行擴大一下,同時也方便工廠的管理,而且生產(chǎn)非液晶顯示器電路板的技術(shù)人員對非液晶顯示的其余部件的生產(chǎn)具有指導(dǎo)的作用,生產(chǎn)液晶顯示器電路板也是同理??偨?jīng)理發(fā)現(xiàn)這是一個不錯的主意。
再回到軟件開發(fā)的過程中來,工廠A和B就是之前所說的C++設(shè)計模式——工廠方法模式;總經(jīng)理再次建立工廠C和D,就是重復(fù)C++設(shè)計模式——工廠方法模式,只是生產(chǎn)的產(chǎn)品不同罷了。這樣做的弊端就如參謀所說的那樣,增加了管理成本和人力成本。在面向?qū)ο箝_發(fā)的過程中,是很注重對象管理和維護(hù)的,對象越多,就越難進(jìn)行管理和維護(hù);如果工廠數(shù)量過多,那么管理和維護(hù)的成本將大大增加;雖然生產(chǎn)的是不同的產(chǎn)品,但是可以二者之間是有微妙的關(guān)系的,如參謀所說,技術(shù)人員的一些技術(shù)經(jīng)驗是可以借鑒的,這就相當(dāng)于同一個類中的不同對象,之間是可以公用某些資源的。那么,增加一條流水線,擴大廠房,當(dāng)然是最好的主意了。
實際問題已經(jīng)得到了解決,那么如何使用設(shè)計模式模擬這個實際的問題呢?那就是接下來所說的抽象工廠模式。
UML類圖
現(xiàn)在要講的抽象工廠模式,就是工廠方法模式的擴展和延伸,但是抽象工廠模式,更有一般性和代表性;它具有工廠方法具有的優(yōu)點,也增加了解決實際問題的能力。
如圖所示,抽象工廠模式,就好比是兩個工廠方法模式的疊加。抽象工廠創(chuàng)建的是一系列相關(guān)的對象,其中創(chuàng)建的實現(xiàn)其實就是采用的工廠方法模式。在工廠Factory中的每一個方法,就好比是一條生產(chǎn)線,而生產(chǎn)線實際需要生產(chǎn)什么樣的產(chǎn)品,這是由Factory1和Factory2去決定的,這樣便延遲了具體子類的實例化;同時集中化了生產(chǎn)線的管理,節(jié)省了資源的浪費。
適用場合
工廠方法模式適用于產(chǎn)品種類結(jié)構(gòu)單一的場合,為一類產(chǎn)品提供創(chuàng)建的接口;而抽象工廠方法適用于產(chǎn)品種類結(jié)構(gòu)多的場合,主要用于創(chuàng)建一組(有多個種類)相關(guān)的產(chǎn)品,為它們提供創(chuàng)建的接口;就是當(dāng)具有多個抽象角色時,抽象工廠便可以派上用場。
代碼實現(xiàn)
/*
** FileName : AbstractFactoryPatternDemo
** Author : Jelly Young
** Date : 2013/11/19
** Description : More information
*/
#include <iostream>
using namespace std;
// Product A
class ProductA
{
public:
virtual void Show() = 0;
};
class ProductA1 : public ProductA
{
public:
void Show()
{
cout<<"I'm ProductA1"<<endl;
}
};
class ProductA2 : public ProductA
{
public:
void Show()
{
cout<<"I'm ProductA2"<<endl;
}
};
// Product B
class ProductB
{
public:
virtual void Show() = 0;
};
class ProductB1 : public ProductB
{
public:
void Show()
{
cout<<"I'm ProductB1"<<endl;
}
};
class ProductB2 : public ProductB
{
public:
void Show()
{
cout<<"I'm ProductB2"<<endl;
}
};
// Factory
class Factory
{
public:
virtual ProductA *CreateProductA() = 0;
virtual ProductB *CreateProductB() = 0;
};
class Factory1 : public Factory
{
public:
ProductA *CreateProductA()
{
return new ProductA1();
}
ProductB *CreateProductB()
{
return new ProductB1();
}
};
class Factory2 : public Factory
{
ProductA *CreateProductA()
{
return new ProductA2();
}
ProductB *CreateProductB()
{
return new ProductB2();
}
};
int main(int argc, char *argv[])
{
Factory *factoryObj1 = new Factory1();
ProductA *productObjA1 = factoryObj1->CreateProductA();
ProductB *productObjB1 = factoryObj1->CreateProductB();
productObjA1->Show();
productObjB1->Show();
Factory *factoryObj2 = new Factory2();
ProductA *productObjA2 = factoryObj2->CreateProductA();
ProductB *productObjB2 = factoryObj2->CreateProductB();
productObjA2->Show();
productObjB2->Show();
if (factoryObj1 != NULL)
{
delete factoryObj1;
factoryObj1 = NULL;
}
if (productObjA1 != NULL)
{
delete productObjA1;
productObjA1= NULL;
}
if (productObjB1 != NULL)
{
delete productObjB1;
productObjB1 = NULL;
}
if (factoryObj2 != NULL)
{
delete factoryObj2;
factoryObj2 = NULL;
}
if (productObjA2 != NULL)
{
delete productObjA2;
productObjA2 = NULL;
}
if (productObjB2 != NULL)
{
delete productObjB2;
productObjB2 = NULL;
}
}
上一篇:C++回溯法實例分析
欄 目:C語言
本文標(biāo)題:C++設(shè)計模式之抽象工廠模式
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/3340.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10APUE筆記之:進(jìn)程環(huán)境詳解
- 01-10c++中inline的用法分析
- 01-10用C++實現(xiàn)DBSCAN聚類算法
- 01-10全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
- 01-10深入C/C++浮點數(shù)在內(nèi)存中的存儲方式詳解


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-11ajax實現(xiàn)頁面的局部加載
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實例總結(jié)
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改


