软件爱 设计模式--工厂模式(简单工厂,工厂方法,抽象工厂)

 软件领域中的设计模式为开发人员提供了一种使用专家设计经验的有效途径。设计模式中运用了面向对象编程语言的重要特性:封装、继承、多态,真正领悟设计模式的精髓是可能一个漫长的过程,需要大量实践经验的积累。最近看设计模式的书,对于每个模式,用C++写了个小例子,加深一下理解。主要参考《大话设计模式》和《设计模式:可复用面向对象软件的基础》两本书。本文介绍工厂模式的实现。

       工厂模式属于创建型模式,大致可以分为三类,简单工厂模式、工厂方法模式、抽象工厂模式。听上去差不多,都是工厂模式。下面一个个介绍,首先介绍简单工厂模式,它的主要特点是需要在工厂类中做判断,从而创造相应的产品。当增加新的产品时,就需要修改工厂类。有点抽象,举个例子就明白了。有一家生产处理器核的厂家,它只有一个工厂,能够生产两种型号的处理器核。客户需要什么样的处理器核,一定要显示地告诉生产工厂。下面给出一种实现方案。

一.简单工厂 (违背原则,不能使用)

  1. enum CTYPE {COREA, COREB};     
  2. class SingleCore    
  3. {    
  4. public:    
  5.     virtual void Show() = 0;  
  6. };    
  7. //单核A    
  8. class SingleCoreA: public SingleCore    
  9. {    
  10. public:    
  11.     void Show() { cout<<"SingleCore A"<<endl; }    
  12. };    
  13. //单核B    
  14. class SingleCoreB: public SingleCore    
  15. {    
  16. public:    
  17.     void Show() { cout<<"SingleCore B"<<endl; }    
  18. };    
  19. //唯一的工厂,可以生产两种型号的处理器核,在内部判断    
  20. class Factory    
  21. {    
  22. public:     
  23.     SingleCore* CreateSingleCore(enum CTYPE ctype)    
  24.     {    
  25.         if(ctype == COREA) //工厂内部判断    
  26.             return new SingleCoreA(); //生产核A    
  27.         else if(ctype == COREB)    
  28.             return new SingleCoreB(); //生产核B    
  29.         else    
  30.             return NULL;    
  31.     }    
  32. };    

             

             Factory  * ft = new Factory (1);

 

       这样设计的主要缺点之前也提到过,就是要增加新的核类型时,就需要修改工厂类。这就违反了开放封闭原则:软件实体(类、模块、函数)可以扩展,但是不可修改于是,工厂方法模式出现了。所谓工厂方法模式,是指定义一个用于创建对象的接口,让子类决定实例化哪一个类。Factory Method使一个类的实例化延迟到其子类。

       听起来很抽象,还是以刚才的例子解释。这家生产处理器核的产家赚了不少钱,于是决定再开设一个工厂专门用来生产B型号的单核,而原来的工厂专门用来生产A型号的单核。这时,客户要做的是找好工厂,比如要A型号的核,就找A工厂要;否则找B工厂要,不再需要告诉工厂具体要什么型号的处理器核了。下面给出一个实现方案。

二.工厂方法模式

[cpp]  view plain  copy
 
  print ?
  1. class SingleCore    
  2. {    
  3. public:    
  4.     virtual void Show() = 0;  
  5. };    
  6. //单核A    
  7. class SingleCoreA: public SingleCore    
  8. {    
  9. public:    
  10.     void Show() { cout<<"SingleCore A"<<endl; }    
  11. };    
  12. //单核B    
  13. class SingleCoreB: public SingleCore    
  14. {    
  15. public:    
  16.     void Show() { cout<<"SingleCore B"<<endl; }    
  17. };    
  18. class Factory    
  19. {    
  20. public:    
  21.     virtual SingleCore* CreateSingleCore() = 0;  
  22. };    
  23. //生产A核的工厂    
  24. class FactoryA: public Factory    
  25. {    
  26. public:    
  27.     SingleCoreA* CreateSingleCore() { return new SingleCoreA; }    
  28. };    
  29. //生产B核的工厂    
  30. class FactoryB: public Factory    
  31. {    
  32. public:    
  33.     SingleCoreB* CreateSingleCore() { return new SingleCoreB; }    
  34. };   
  35. int main()  
    {  
    	Factory *_Ft= new FactoryA;
    	_Ft->CreateSingleCore()->Show();
     
    	_Ft = new FactoryB;
    	_Ft->CreateSingleCore()->Show();
    	return 0;  
    } 

 

    工厂方法模式也有缺点,每增加一种产品,就需要增加一个对象的工厂。如果这家公司发展迅速,推出了很多新的处理器核,那么就要开设相应的新工厂。在C++实现中,就是要定义一个个的工厂类。显然,相比简单工厂模式,工厂方法模式需要更多的类定义。

       既然有了简单工厂模式和工厂方法模式,为什么还要有抽象工厂模式呢?它到底有什么作用呢?还是举这个例子,这家公司的技术不断进步,不仅可以生产单核处理器,也能生产多核处理器。现在简单工厂模式和工厂方法模式都鞭长莫及。抽象工厂模式登场了。它的定义为提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。具体这样应用,这家公司还是开设两个工厂,一个专门用来生产A型号的单核多核处理器,而另一个工厂专门用来生产B型号的单核多核处理器,下面给出实现的代码。

三:抽象工厂

[cpp]  view plain  copy
 
  print ?
  1. //单核    
  2. class SingleCore     
  3. {    
  4. public:    
  5.     virtual void Show() = 0;  
  6. };    
  7. class SingleCoreA: public SingleCore      
  8. {    
  9. public:    
  10.     void Show() { cout<<"Single Core A"<<endl; }    
  11. };    
  12. class SingleCoreB :public SingleCore    
  13. {    
  14. public:    
  15.     void Show() { cout<<"Single Core B"<<endl; }    
  16. };    
  17. //多核    
  18. class MultiCore      
  19. {    
  20. public:    
  21.     virtual void Show() = 0;  
  22. };    
  23. class MultiCoreA : public MultiCore      
  24. {    
  25. public:    
  26.     void Show() { cout<<"Multi Core A"<<endl; }    
  27.     
  28. };    
  29. class MultiCoreB : public MultiCore      
  30. {    
  31. public:    
  32.     void Show() { cout<<"Multi Core B"<<endl; }    
  33. };    
  34. //工厂    
  35. class CoreFactory      
  36. {    
  37. public:    
  38.     virtual SingleCore* CreateSingleCore() = 0;  
  39.     virtual MultiCore* CreateMultiCore() = 0;  
  40. };    
  41. //工厂A,专门用来生产A型号的处理器    
  42. class FactoryA :public CoreFactory    
  43. {    
  44. public:    
  45.     SingleCore* CreateSingleCore() { return new SingleCoreA(); }    
  46.     MultiCore* CreateMultiCore() { return new MultiCoreA(); }    
  47. };    
  48. //工厂B,专门用来生产B型号的处理器    
  49. class FactoryB : public CoreFactory    
  50. {    
  51. public:    
  52.     SingleCore* CreateSingleCore() { return new SingleCoreB(); }    
  53.     MultiCore* CreateMultiCore() { return new MultiCoreB(); }    
  54. };   

        至此,工厂模式介绍完了。利用Rational Rose 2003软件,给出三种工厂模式的UML图,加深印象。

         简单工厂模式的UML图:

         工厂方法的UML图:

         抽象工厂模式的UML图:

 

抽象工厂列子2

引用http://blog.csdn.net/blpluto/article/details/4562111

 

//产品基类
#include <iostream>
class FoodProduct
{
public:
	FoodProduct(void) {};
	~FoodProduct(void) {};
	virtual void Delicious(){std::cout<<"FoodProduct Delicious"<<std::endl;};
};

//红烧鱼类
class BraisingFish :public FoodProduct
{
public:
	BraisingFish(void){};
	~BraisingFish(void) {};
	virtual void Delicious(){std::cout<<"BraisingFish Delicious"<<std::endl;};
};

//清蒸鱼类
class SteamedFish :public FoodProduct
{
public:
	SteamedFish(void){};
	~SteamedFish(void){};
	virtual void Delicious(){std::cout<<"SteamedFish Delicious"<<std::endl;};
};


//川式红烧鱼
class ChuanBraisingFish :public BraisingFish
{
public:
	ChuanBraisingFish(void){std::cout<<"this is ChuanBraisingFish!"<<std::endl;};
	~ChuanBraisingFish(void){};
	virtual void Delicious(){std::cout<<"ChuanBraisingFish Delicious"<<std::endl;};
};

//鲁式红烧鱼
class LuBraisingFish :public BraisingFish
{
public:
	LuBraisingFish(void){std::cout<<"this is LuBraisingFish!"<<std::endl;};
	~LuBraisingFish(void){};
	virtual void Delicious(){std::cout<<"LuBraisingFish Delicious"<<std::endl;};
};

// 川式清蒸鱼
class ChuanSteamFish :public SteamedFish
{
public:
	ChuanSteamFish(void){ std::cout<<"this is ChuanSteamFish!"<<std::endl;};
	~ChuanSteamFish(){};
	virtual void Delicious(){std::cout<<"ChuanSteamFish Delicious"<<std::endl;};
};

// 鲁式清蒸鱼
class LuSteamedFish : public SteamedFish
{
public:
	LuSteamedFish (void){ std::cout<<"this is LuSteamedFish!"<<std::endl; };
	~LuSteamedFish(){};
	virtual void Delicious(){std::cout<<"LuSteamedFish Delicious"<<std::endl;};
};


//下面实现烹饪工厂
//烹饪总工厂
class CookFactory
{
public:
	CookFactory(void){};
	~CookFactory(void){};
	virtual BraisingFish *CookBraisingFish(){return new BraisingFish();};
	virtual SteamedFish *CookSteamedFish(){return new SteamedFish();};
};

//鲁菜工厂
class LuCookFactory :public CookFactory
{
public:
	LuCookFactory(void){};
	~LuCookFactory(void){};
	virtual BraisingFish *CookBraisingFish();
	virtual SteamedFish *CookSteamedFish();
};

//川菜工厂
class ChuanCookFactory :public CookFactory
{
public:
	ChuanCookFactory(void){};
	~ChuanCookFactory(void){};
	virtual BraisingFish *CookBraisingFish();
	virtual SteamedFish *CookSteamedFish();
};

//鲁菜工厂的实现
BraisingFish *LuCookFactory::CookBraisingFish()
{
	std::cout<<"BraisingFishFactory is Cooked!"<<std::endl;
	return new LuBraisingFish();
}

SteamedFish *LuCookFactory::CookSteamedFish()
{
	std::cout<<" StramedFishFactory is Cooked!"<<std::endl;

	return new LuSteamedFish();
}

//川菜工厂的实现
BraisingFish *ChuanCookFactory::CookBraisingFish()
{
	std::cout<<"ChuanBraisingFactory is Cooked!"<<std::endl;
	return new ChuanBraisingFish();
}

SteamedFish *ChuanCookFactory::CookSteamedFish()
{
	std::cout<<"ChuanSteamedFactory is Cooked!"<<std::endl;
	return new ChuanSteamFish();
}


//下面是客户端的实现
int main(void)
{
	CookFactory *cookFac = new LuCookFactory();

	// 鲁菜工厂
	BraisingFish *braFish = cookFac->CookBraisingFish();
	braFish->Delicious(); 
	std::cout<<"******************************************\n";
	delete braFish;

	SteamedFish *steFish = cookFac->CookSteamedFish();
	steFish->Delicious();
	std::cout<<"******************************************\n";
	delete steFish;
	delete cookFac;

	// 川菜工厂
	cookFac = new ChuanCookFactory();
	braFish = cookFac->CookBraisingFish();
	braFish->Delicious();
	std::cout<<"******************************************\n";
	delete braFish;

	steFish = cookFac->CookSteamedFish();
	steFish->Delicious();
	delete steFish;
	system("pause");

	return 0;
}

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值