一、UML图

 

二、概念

策略模式:他定义了算法家族,分别封装起来,让他们之间可以互相替换,此模式让算法的变化,不会影响到使用算法的客户。

 

三、优点

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

(2)策略模式的Strategy类曾是为Context定义了一些列的可供重用的算法或行为。集成有助于析取出这些算法中的公共功能。

(3)策略模式简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试。

(4)策略模式就是用来封装算法的。

(5)只要在分析过程中听到需要在不同时间应用不同的业务规则,就可以考虑使用策略模式处理这种变化的可能性。

(6)简单工厂模式需要让客户端认识两个类,而策略模式和简单工厂模式结合的用法,客户端只需要认识一个类Context即可。

四 与工厂模式的区别:

工厂模式用来选择分支,产生不同的产品,(类)

策略模式是针对算法的,不同的算法用不同的类

 #include <iostream>
using namespace std; // 抽象产品类
class Operation{
protected:
double num1;
double num2;
public:
double get_n1(){
return num1;
}
double get_n2(){
return num2;
}
void set_n1(int num){
num1 = num;
}
void set_n2(int num){
num2 = num;
}
virtual double GetResult(){
double result = ;
return result;
} };
//具体产品类
class OperationAdd :public Operation{
public:
double GetResult(){
double result = ;
result = num1 + num2;
return result;
}
}; //具体产品类
class OperationSub :public Operation{
public:
double GetResult(){
double result = ;
result = num1 - num2;
return result;
}
}; //具体产品类
class OperationMul :public Operation{
public:
double GetResult(){
double result = ;
result = num1 * num2;
return result;
}
}; //具体产品类
class OperationDiv :public Operation{
public:
double GetResult(){
double result = ;
if (num2 != )
result = num1 / num2;
return result;
}
};
//工厂类 class OperationFactory{
public:
Operation* createOperation(char type){
Operation* oper = NULL;
switch (type)
{
case '+':
oper = new OperationAdd;
break;
case '-':
oper = new OperationSub;
break;
case '*':
oper = new OperationMul;
break;
case '/':
oper = new OperationDiv;
break;
}
return oper;
}
}; //策略类
class Context{
private:
Operation* op_;
public:
Context(char type){
OperationFactory of;
op_ = of.createOperation(type);
}
double executeOperation(double num1, double num2){
op_->set_n1(num1);
op_->set_n2(num2);
return op_->GetResult();
} }; void main(){ double res = ;
Context co = Context('+');
res = co.executeOperation(, );
cout << res << endl; Context co2 = Context('-');
res = co2.executeOperation(, );
cout << res << endl; system("pause");
}

参考:

http://www.runoob.com/design-pattern/strategy-pattern.html

https://blog.csdn.net/xiqingnian/article/details/41855391

最新文章

  1. bzoj-1096 1096: [ZJOI2007]仓库建设(斜率优化dp)
  2. 新增了个job
  3. [JS] jQuery选择器
  4. table_tricks_基于bootstrap
  5. &#39;UIShell.OSGi.MvcWebExtension.BundleRuntimeControllerFactory&#39; did not return a controller for the name &#39;Home&#39;.
  6. POJ 1456 Supermarket(贪心+并查集优化)
  7. [置顶] 深入浅出Spring(三) AOP详解
  8. 使用Travis CI自动部署Hexo博客
  9. Android驱动中的Kconfig文件与Makefile文件
  10. MySQL中实现连续日期内数据统计,缺省天数0补全
  11. java实现栈的简单操作
  12. SpringCache实战遇坑
  13. Hystrix入门与分析(一):初识Hystrix
  14. 三步解决阿里云绑定公网IP地址失败解决方案
  15. cglib实现动态代理简单使用
  16. Python高阶函数_map/reduce/filter函数
  17. web框架--MVC、MTV
  18. lucene教程--全文检索技术
  19. @slf4j注解找不到 log 变量
  20. C-C和指针作业题(第一章)

热门文章

  1. [模式匹配] AC 自动机 模式匹配
  2. 状压dp的另一种形式
  3. webstorm背景颜色更改
  4. kubernetes的apiserver
  5. sql server系统存储过程大全
  6. bat实现获取文件每行内容,for循环中运行多条命令
  7. Linux下高并发socket最大连接数各种限制的调优
  8. MySQL语法和用户授权
  9. Android使得Fragment 切换时不重新实例化
  10. dubbo发布和引用服务