策略模式

官方定义:
策略模式是一种定义一些列算法的方法,从概念上来看,所有这些算法完成的都是相同的工作,只是实现不同,它可以以相同的方式调用所有的算法,减少了各种算法类别与使用算法类之间的耦合。

自己理解:
用来避免设计的类中同时包含众多的实现,并且实现算法之间用开关型语句(例如:if else if, switch case 等)进行多级判断所导致的代码改写复用困难等问题。

UML图:
在这里插入图片描述
代码示例:

// Step1: 定义抽象策略类
class Strategy {
public:
	virtual void AlgorithmInterface() = 0;
	virtual ~Strategy() {}
};

//Step2: 定义具体策略类
class ConcreatStrategyA :public Strategy {
public:
	void AlgorithmInterface() {
		//具体代码实现
	}
};

class ConcreatStrategyB :public Strategy {
public:
	void AlgorithmInterface() {
		//具体代码实现
	}
};

class ConcreatStrategyC :public Strategy {
public:
	void AlgorithmInterface() {
		//具体代码实现
	}
};

//Step3:定义上下文
class Context {
private:
	Strategy* strategy;
public:
	Context(Strategy* s) :strategy(s) {}
	void ContextInterface() {
		// 功能代码
		strategy->AlgorithmInterface();
		//功能代码
	}
	~Context() {
		delete strategy;
	}
};

//Step4: 定义客户端代码
int main() {
	Context* context = new Context(new ConcreatStrategyA);
	context->ContextInterface();

	Context* context = new Context(new ConcreatStrategyB);
	context->ContextInterface();

	Context* context = new Context(new ConcreatStrategyC);
	context->ContextInterface();
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值