策略模式:定义一系列算法,把它们一个个封装起来,并且使它们可以相互替换,本模式使得算法可独立于使用它的客户而变化。

三种角色:

1、策略:一个抽象类,这个接口定义了若干个算法标识,即多个虚函数,这些个算法的实现在不同场景可能会不一样。

2、具体策略:它实现了策略,实现抽象类中定义个算法标识,即给出具体算法实现。

3、上下文:它依赖于策略抽象类,即上下文 包含 策略声明的指针,上下文中提供一个方法,该方法委托策略调用具体策略所实现的算法。

C++实现包含三个文件,一个头文件策略类的声明strategy.h,两个源文件strategy.cpp 和context.cpp,一个是具体策略中方法的实现,另一个是上下文的源文件,将测试用的主函数也放在这个文件中。

1、strategy.h

 #ifndef _STRATEGY_H_
#define _STRATEGY_H_ //抽象策略类
class ComputeStrategy{
public:
//这里参数是a[] 实际上相当于指针 所以想获取其长度 非常困难(应该获取不了) 所以传入一个个数
virtual double computeScore(double a[], int len) = ;
}; //具体策略类
class StrategyOne : public ComputeStrategy
{
public:
double computeScore(double a[], int len);
}; class StrategyTwo : public ComputeStrategy
{
public:
double computeScore(double a[], int len);
}; class StrategyThree : public ComputeStrategy
{
public:
double computeScore(double a[], int len);
}; #endif

2、strategy.cpp

 #include "strategy.h"
#include <iostream>
#include <cmath>
#include <algorithm> double StrategyOne::computeScore(double a[], int len)
{
double score = , sum = ;
for (int i = ; i < len; i++)
{
sum += a[i];
}
score = sum / len;
return score;
} double StrategyTwo::computeScore(double a[], int len)
{
double score = , multi = ;
for (int i = ; i < len; i++)
{
multi *= a[i];
}
score = std::pow(multi, 1.0 / len);
return score;
} double StrategyThree::computeScore(double a[], int len)
{
double score = , sum = ;
if ( >= len)
{
return 0.0;
} std::sort(a, a + len);
for (int i = ; i < len - ; i++)
{
sum += a[i];
}
score = sum / (len - );
return score; }

3、context.cpp

 #include <iostream>
#include "strategy.h" //上下文类 依赖策略类
class Context
{
public:
ComputeStrategy* myStrategy;
public:
void setStrategy(ComputeStrategy* strategy)
{
myStrategy = strategy;
}
double getPersonScore(double a[], int len)
{
if (NULL != myStrategy)
{
std::cout << "myStrategy not null" << std::endl;
return myStrategy->computeScore(a, len);
}
else
{
return ;
} } }; int main()
{
Context *game = new Context();
double a[] = { 9.12, 9.25, 8.87, 9.99, 6.99, 7.88 };
int len = sizeof(a) / sizeof(double); game->setStrategy(new StrategyOne());
double r1 = game->getPersonScore(a,len);
std::cout << "strategy one: " << r1 << std::endl; game->setStrategy(new StrategyTwo());
double r2 = game->getPersonScore(a, len);
std::cout << "strategy two: " << r2 << std::endl; game->setStrategy(new StrategyThree());
double r3 = game->getPersonScore(a, len);
std::cout << "strategy three : " << r3 << std::endl; delete game;
game = NULL; return ;
}

在实现中,值得注意的是,设置具体的策略的时候,函数的形参是类的指针。然后本例子实现的是一个统计分数数组的平均分的不同策略,而C++中在数组作为参数的时候,实际上是退化为指针了,而这样是无法获取数组的长度的,所以

也传入了一个长度参数。

(三)策略模式-C++实现的更多相关文章

  1. Java设计模式从精通到入门三 策略模式

    介绍 我尽量用最少的语言解释总结: Java23种设计模式之一,属于行为型模式.一个类的行为或者算法可以在运行时更改,策略对象改变context对象执行算法. 应用实例: ​ 以周瑜赔了夫人又折兵的例 ...

  2. JS 设计模式三 -- 策略模式

    策略模式 概念 定义一系列算法,把它们一个个封装起来. 将算法的使用与算法的实现分离开来 实现 // 加权映射关系 var levelMap = { S: 10, A: 8, B: 6, C: 4 } ...

  3. Javascript模式(三) 策略模式

    var data = { "username" : "zhangsan", "password" : "12345690" ...

  4. 设计模式:HelloWorld之策略模式

    一.概述 策略模式 定义了算法族,分别封装起来,让他们可以互相替换,此模式让算法的变化独立于使用算法的客户. 策略模式的三要素: 抽象策略角色: 策略类,通常由一个接口或者抽象类实现. 具体策略角色: ...

  5. 计算器软件实现系列(六)windowform窗体+SQL+策略模式

    一 整体概述 这个计算器软件的功能和以前的功能基本上一样,只不过是数据的保存形式发生了变化,,以前用的是txt文件保存,现在更正用SQL数据库,现在更改了以前的文件保存形式,是三层架构中数据层的更换, ...

  6. Javascript设计模式学习三(策略模式)

    定义:定义一系列的算法,把它们一个个封装起来,并且使它们可以互相替换.目的:将算法的使用和算法的实现分离开来.比如: if(input == 'A'){ return 1; } if(input == ...

  7. JAVA中的设计模式三(策略模式)

    问题: 如何让算法和对象分开来,使得算法可以独立于使用它的客户而变化?   方案: 把一个类中经常改变或者将来可能改变的部分提取出来,作为一个接口,然后在类中包含这个对象的实例,这样类的实例在运行时就 ...

  8. 两种语言实现设计模式(C++和Java)(三:策略模式)

    策略模式是指定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换.本模式使得算法可独立于使用它的客户而变化.也就是说这些算法所完成的功能一样,对外的接口一样,只是各自实现上存在差异.用策略模式 ...

  9. JavaScript设计模式(三) - 策略模式

    什么是策略模式? 策略模式支持在运行时由使用者选择合适的算法,对于使用者而言不用关心背后的具体实现,由使用者自动根据当前程序执行的上下文和配置,从已有的算法列列表中选择出合适的算法来处理当前任务.   ...

随机推荐

  1. 基于 Node.js 平台的web开发框架-----express

    express官网:---->传送门  express express框架有许多功能,比如路由配置,中间件,对于想配置服务器的前端来说,非常便捷 自从node发展之后,基于nodejs的开发框架 ...

  2. scroll事件实现监控滚动条并分页显示示例(zepto.js)

    scroll事件实现监控滚动条并分页显示示例(zepto.js  ) 需求:在APP落地页上的底部位置显示此前其他用户的购买记录,要求此div盒子只显示3条半,但一页有10条,div内的滑动条滑到一页 ...

  3. JavaScript学习笔记-基础语法、类型、变量

    基础语法.类型.变量   非数字值的判断方法:(因为Infinity和NaN他们不等于任何值,包括自身) 1.用x != x ,当x为NaN时才返回true; 2.用isNaN(x) ,当x为NaN或 ...

  4. 送给我的朋友——Cry on my shoulder

    If the hero never comes to you如果你的真命天子仍未来到 If you need someone you"re feeling blue如果你情绪低落需要有人陪伴 ...

  5. iOS UIAlertController

    在Xcode的iOS9.0 SDK中,UIAlertView和UIActionSheet都被UIAlertController取代. 在iOS 9中,UIAlertController在功能上是和UI ...

  6. 超人学院二期学员分享hadoop工作经验

    定于2月17日--2月23日的某一天,邀请咱们学员分享一下hadoop工作经验.对于没工作过的同学或者没从事过hadoop工作的同学,抓住机会啊,你可以提前准备自己关心的各种问题! 具体时间请关注QQ ...

  7. 开发Android系统内置应用小记

    Android系统内置应用可以使用更多的API.更高的权限,与开发普通应用最大的差别在于编译,内置应用编译需要用到Android.mk文件.下面是我在开发过程中的一些小记. 1.在AndroidMai ...

  8. 什么是java path环境变量

    参考:https://docs.oracle.com/javase/tutorial/essential/environment/paths.html 从orcle官网的文档中可以看到java pat ...

  9. iOS如何获取网络图片(二)

    ios如何获取图片(二)无沙盒下 解决问题 *解决问题1:tableView滑动卡顿,图片延时加载 解决方法:添加异步请求,在子线程里请求网络,在主线程刷新UI *解决问题2:反复请求网络图片,增加用 ...

  10. 软工_Alpha阶段事后分析总计

    1.设想和目标 1.1 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件主要解决狼人杀玩家在游戏时的一些痛点.因为之前自己对于游戏中那些不方便的地方有过体 ...