C++设计模式---Strategy模式
一、前言
学习的第一个设计模式!不知道理解的对不对,期望大家一起多交流~
Strategy模式:策略模式,定义了算法族,分别封装起来,此模式可以让算法的变化独立于使用算法的客户。Strategy模式将逻辑算法封装到一个类中,通过组合的方式将具体的算法实现在组合对象中,再通过委托的方式将抽象的接口的实现委托给组合对象实现。其模型结构图如下:

二、Strategy策略实例
最近在写遥感影像融合相关算法,PCA、Brovey和SFIM算法,正好可以用于这次学习Strategy策略。
关于这三个融合算法都属于替换类算法,大概思路就是用一个替换另外一个。然后获得高分辨的高频信息和地分辨的光谱信息。
依据Strategy策略的思想,我们首先定义一个CContextFusion类,里面有一个DoFusionAction()方法,主要用于实现算法逻辑抽象接口,其头文件如下:
#pragma once
#include "StrategyFusion.h" class CStrategyFusion; class CContextFusion
{
public:
CContextFusion(CStrategyFusion *stg);
~CContextFusion(void); bool DoFusionAction(); private:
CStrategyFusion *m_stg;
};
cpp文件如下:
#include "ContextFusion.h" CContextFusion::CContextFusion( CStrategyFusion *stg )
{
m_stg = stg;
}
CContextFusion::~CContextFusion(void)
{
if(!m_stg)
delete m_stg;
} bool CContextFusion::DoFusionAction()
{
return m_stg->runFusion();
}
完成这个类后,我们首先定义一个融合算法超类CStrategyFusion,考虑到以上三种算法都要实现影像的重采样和增益系数的计算。为此,我们把这两个方法的实现放在超类中,对于其他与融合算法相关的方法,放到具体的算法类中。其类结构关系如下所示:

头文件分别如下:
#pragma once
#include <iostream>
#include <string>
#include <omp.h>
#include <gdal_alg_priv.h> class CStrategyFusion
{
public:
CStrategyFusion(void);
virtual ~CStrategyFusion(void);
virtual bool runFusion() = 0; protected:
int ReSampleMSSToPAN();
void getGAIN(); std::string m_panFileName;
std::string m_mssFileName;
std::string m_resampleFileName;
std::string m_FusionFileName;
GDALDataType m_dt;
int m_resampleModel; int m_gainX; // X方向增益像元个数
int m_gainY; // Y方向增益像元个数
int m_FusionWidth; // 融合后影像宽
int m_FusionHeight; // 融合后影像高
double m_FusionGeoTransform[6]; //private: };
#pragma once
#include "strategyfusion.h" class CStrategyFusionByPCA :
public CStrategyFusion
{
public:
CStrategyFusionByPCA(void);
~CStrategyFusionByPCA(void); bool runFusion(); private:
double *calMSSMean();
double *calCovMaxtrix(double *bandMean);
bool eejcb(double a[],int n,double v[],double eps,int jt);
void sortEigenVector( int iBandCount,double * eigenVector,double * covAfterEejcb);
void PCATransform(double *eigenVector);
double* cdf(int *h,int length);
void matchHistogram();
void inverseMatrix( double *matrix, int n );
void invertPCA(double * eigenVector); std::string m_PCAFileName;
std::string m_PanNewFileName;
};
#pragma once
#include "strategyfusion.h" class CStrategyFusionByBrovey :
public CStrategyFusion
{
public:
CStrategyFusionByBrovey(void);
~CStrategyFusionByBrovey(void); bool runFusion(); private:
bool CNByBrovery();
};
#pragma once
#include "strategyfusion.h" class CStrategyFusionBySFIM :
public CStrategyFusion
{
public:
CStrategyFusionBySFIM(void);
~CStrategyFusionBySFIM(void); bool runFusion(); private:
bool FilterMeanByPan();
bool SFIM();
};
总结:通过Strategy策略,我们可以自由、方便的补充新的基于替换类的融合算法,甚至其他所有的融合算法,换句话说就是可以自由定制自己的融合算法类,这种基于接口的实现不会因为继承而导致不可预计的危险。
C++设计模式---Strategy模式的更多相关文章
- android 开发设计模式---Strategy模式
假设我们要出去旅游,而去旅游出行的方式有很多,有步行,有坐火车,有坐飞机等等.而如果不使用任何模式,我们的代码可能就是这样子的. 12345678910111213141516171819202122 ...
- Groovy 设计模式 -- Strategy 模式
策略模式 https://en.wikipedia.org/wiki/Strategy_pattern In computer programming, the strategy pattern (a ...
- 设计模式-策略模式(Strategy Model)
1.概述 在开发过程中常常会遇到类似问题,实现一个功能的时候往往有多种算法/方法(策略),我们可以根据环境的不同来使用不同的算法或策略来实现这一功能. 如在人物比较排序的实现中,我们有 ...
- 策略模式设计模式(Strategy)摘录
23种子GOF设计模式一般分为三类:创建模式.结构模型.行为模式. 创建模式抽象的实例.一个系统独立于怎样创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而一个对象创建型模式将 ...
- [.net 面向对象程序设计深入](26)实战设计模式——策略模式 Strategy (行为型)
[.net 面向对象程序设计深入](26)实战设计模式——策略模式 Strategy (行为型) 1,策略模式定义 策略模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.策略模 ...
- Java设计模式(18)策略模式(Strategy模式)
Strategy是属于设计模式中 对象行为型模式,主要是定义一系列的算法,把这些算法一个个封装成单独的类. Stratrgy应用比较广泛,比如,公司经营业务变化图,可能有两种实现方式,一个是线条曲线, ...
- 设计模式之——浅谈strategy模式(策略模式)
strategy模式,即策略模式.个人觉得吧,策略模式更多的是一种思维方式. 首先我们要知道,为什么需要策略模式.举个例子,比如用程序输出今天下午去玩什么. PlayGame 玩游戏 package ...
- 设计模式(十)Strategy模式
Strategy模式,就是用来整体地替换算法,可以轻松地以不同的算法解决同一个问题. 还是根据一个示例程序来理解这种设计模式吧.先看一下示例程序的类图. 然后看示例程序代码. package bigj ...
- C++设计模式-Strategy策略模式
Strategy策略模式作用:定义了算法家族,分别封装起来,让他们之间可以互相替换,此模式让算法的变化,不会影响到使用算法的客户. UML图: Strategy模式将逻辑(算法)封装到一个类(Cont ...
随机推荐
- Java基础知识强化56:经典排序之快速排序(QuickSort)
1. 快速排序的原理: 快速排序(Quicksort)是对冒泡排序的一种改进. 快速排序由C. A. R. Hoare在1962年提出.它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其 ...
- Linux命令 rpm
rpm -q samba --查询程序是否安装rpm -qa | grep httpd --[搜索指定rpm包是否安装] --all搜索*http ...
- hdu 1042
貌似之前也写过这个题目的解题报告...老了,记性不好 从贴一遍吧! 代码理解很容易 AC代码: #include <iostream> #include <stdio.h> # ...
- .NET Core初体验 - 在Mac下运行第一个Web示例程序
要说最近两天程序猿之间最喜欢吹水的事是什么?那绝壁是甲骨文要放弃Java!简直做梦都要笑醒!由于公司的产品线全面转向Java,最近几个月也一直在苦学Java技术.已经默默决定了,如果消息证实是真的,我 ...
- 在 sys.servers 中找不到服务器的解决办法,自己解决的
一开始提示,在服务器中找不到在 sys.servers 中找不到服务器 'QPAccountsDBLink',先用select * from sys.servers ,发现只能查到一个服务器名称,后 ...
- php模块memcache和memcached区别分析
zm总结:尽量使用memcached就好了 1.目前大多数php环境里使用的都是不带d的memcache版本,这个版本出的比较早,是一个原生版本,完全在php框架内开发的.与之对应的带d的memcac ...
- csv 导入到 access中去
Csv中有500万数据,导入到Access中去,每6万条数据为1Table 先是参照着http://support.microsoft.com/kb/257819/zh-cn来写 1.找不到可安装的 ...
- CSS的margin塌陷
一.两个div并列,上面div的margin-bottom和下面div的margin-top会塌陷,也就说会取上面div的margin-bottom和下面div的margin-top的最大值作为两个并 ...
- BASE64的实现
原由 项目中经常需要使用base64进行处理,通过base64可以将特殊字符转化为普通可见字符,便于网络传输,代价是增长了传输长度. base64将每3个byte转化为4个6bit位,然后高位补两个零 ...
- odoo10会计期间
从odoo9,会计模块重构之后,去掉了account.fiscalyear 以及 account.period 这两个模型, 但不表示 odoo 从此就没有 "会计年度"和&quo ...