C++简单工厂模式和策略模式实例

#include <iostream>
#include <string>
using namespace std;

typedef enum StrategyTypeTag
{
	strategyA,
	strategyB,
}StrategyType;

class Strategy{
	public:
	virtual void AlgorithmInterface() = 0;
};

//具体策略 StrategyA
class StrategyA : public Strategy{
	public:
	void AlgorithmInterface(){
		cout << "实现A算法" <<endl;
	}
};

class StrategyB : public Strategy{
	public:
	void AlgorithmInterface() {
		cout << "实现B算法" << endl;
	}
};

class  Context{
	public:
	Context(Strategy *pStrategy):pStrategy(pStrategy){}
	void ContextInterface(){
		pStrategy->AlgorithmInterface();
	}
	private:
	Strategy *pStrategy;
};

class Factory{
	public:
	Strategy* CreateStrategy(StrategyType type)
	{
		switch(type)
		{
			case strategyA:
			return new StrategyA();
			case strategyB:
			return new StrategyB();
			default:
			return NULL;
			
			
		}
	}
};

int main(){
	Factory *pFactory = new Factory();
	
	Strategy *pstrategya = pFactory->CreateStrategy(strategyA);
	Strategy *pstrategyb = pFactory->CreateStrategy(strategyB);
	
	Context *pcontexta = new Context(pstrategya);
	
	Context *pcontextb = new Context(pstrategyb);

	
	pcontexta->ContextInterface();
	pcontextb->ContextInterface();
	if(pFactory)delete pFactory;
	if(pstrategya)delete pstrategya;
	if(pstrategyb)delete pstrategyb;
	if(pcontexta)delete pcontexta;
	if(pcontextb)delete pcontextb;
	
	
	
	return 0;
	
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

九江在天

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值