Command 模式
Command 模式通过将请求封装到一个对象(Command)中,并将请求的接受者存放具体的 ConcreteCommand 类中(Receiver)中,从而实现调用操作的对象和操作的具体实现
者之间的解耦。

Command 模式结构图中,将请求的接收者(处理者)放到 Command 的具体子类
ConcreteCommand 中,当请求到来时(Invoker 发出 Invoke 消息激活 Command 对象) ,
ConcreteCommand 将处理请求交给 Receiver对象进行处理。
////////////Command.h//////////////////////////////////////////////////////////////
#pragma once
class Reciever;
class Command
{
public:
virtual ~Command();
virtual void Excute() = ;
protected:
Command();
private:
}; class ConcreteCommand1 : public Command
{
public:
~ConcreteCommand1();
ConcreteCommand1(Reciever* rec);
void Excute() ;
protected:
private:
Reciever* _rec ;
}; class ConcreteCommand2 : public Command
{
public:
~ConcreteCommand2();
ConcreteCommand2(Reciever* rec);
void Excute() ;
protected:
private:
Reciever* _rec ;
};
/////////Command.cpp/////////////////////////////////////////////////////////////////
#include "Command.h"
#include "Reciever.h"
Command::Command()
{ }
Command::~Command()
{ } ConcreteCommand1::ConcreteCommand1(Reciever* rec)
{
this->_rec = rec ;
}
void ConcreteCommand1::Excute()
{
this->_rec->Action1();
} ConcreteCommand1::~ConcreteCommand1()
{
delete _rec;
} ConcreteCommand2::ConcreteCommand2(Reciever* rec)
{
this->_rec = rec ;
}
void ConcreteCommand2::Excute()
{
this->_rec->Action2();
} ConcreteCommand2::~ConcreteCommand2()
{
delete _rec;
}
//////////////Invoker.h////////////////////////////////////////////////////////////
#pragma once
#include <vector> class Command;
class Invoker
{
public:
void setcmd(Command* cmd);
void Notify();
protected:
private:
std::vector<Command*> _cmds ;
};
//////Invoker.cpp////////////////////////////////////////////////////////////////////
#include "Invoker.h"
#include "Command.h"
#include <vector>
#include <iostream>
using namespace std;
void Invoker::setcmd(Command* cmd)
{
this->_cmds.push_back(cmd);
cout<<"增加请求"<<endl;
} void Invoker::Notify()
{
vector<Command*>::const_iterator it = _cmds.begin();
for (;it != _cmds.end() ; it++)
{
(*it)->Excute();
}
}
////////////Reciever.h//////////////////////////////////////////////////////////////
#pragma once
class Reciever
{
public:
~Reciever();
Reciever();
void Action1();
void Action2();
protected:
private:
};
/////////Reciever.cpp/////////////////////////////////////////////////////////////////
#include "Reciever.h"
#include <iostream>
using namespace std ;
Reciever::Reciever()
{ }
Reciever::~Reciever()
{ }
void Reciever::Action1()
{
cout<<"处理具体的请求1"<<endl;
} void Reciever::Action2()
{
cout<<"处理具体的请求2"<<endl;
}
////////main.cpp//////////////////////////////////////////////////////////////////
#include "Command.h"
#include "Invoker.h"
#include "Reciever.h"
#include <iostream>
using namespace std;
int main()
{
Reciever* rec = new Reciever();//创建处理者
Invoker* inv = new Invoker();//创建请求者 Command* cmd1 = new ConcreteCommand1(rec);
Command* cmd2 = new ConcreteCommand2(rec); //得到请求
inv->setcmd(cmd1);
inv->setcmd(cmd2); //发出请求
inv->Notify(); getchar();
return ;
}
Command 模式的更多相关文章
- C++基础——模拟事务 (1)COMMAND模式
=================================版权声明================================= 版权声明:原创文章 禁止转载 请通过右侧公告中的“联系邮 ...
- Command模式
Command模式只是封装了一个没有任何变量的函数. interface Command{ void Excute();} 具有强烈的分解功能的味道.把函数层面的任务提升到了类的层面(一个类仅仅是为了 ...
- 敏捷软件开发(3)---COMMAND 模式 & Active Object 模式
COMMAND 模式 command模式非常简单,简单到你无法想象的地方. public interface Command { void execute(); } 这就是一个command模式的样子 ...
- 条款19 command 模式与好莱坞法则
当一个函数对象被当做回调时候,就是一个command模式的实例 什么是回调? 回调就是框架知道什么时候干一些事情,但是具体干什么,或许框架一无所知(因为回调函数不是他设计的),而用户则知道发生一个特定 ...
- 开发设计模式(一)Command模式
Command定义 将来自客户端的请求传入一个对象,无需了解这个请求激活的 动作或有关接受这个请求的处理细节. 这是一种两台机器之间通讯联系性质的模式,类似传统过程语 言的 CallBack功能. 优 ...
- 【行为型】Command模式
命令模式是指将用户的请求封装成(命令)对象,从而可将用户不同的请求进行参数化.对这些请求排序或记录请求日志.以及支持回滚恢复操作.记得以前刚开始使用Photoshop时,就发现它的操作历史记录面板特别 ...
- [译]使用Command模式和MediatR简化你的控制器
原文 你希望保持你的controller足够简单. 你的controller越来越臃肿,你听说command模式是一个给controller瘦身的解决方案. 但是你不知道command模式是否适合你的 ...
- Java设计模式(22)命令模式(Command模式)
Command模式是最让我疑惑的一个模式,我在阅读了很多代码后,才感觉隐约掌握其大概原理,我认为理解设计模式最主要是掌握起原理构造,这样才对自己实际编程有指导作用.Command模式实际上不是个很具体 ...
- Xwork概况 XWork是一个标准的Command模式实现,并且完全从web层脱离出来。Xwork提供了很多核心功能:前端拦截机(interceptor),运行时表单属性验证,类型转换,强大的表达式语言(OGNL – the Object Graph NavigationLanguage),IoC(Inversion of Control反转控制)容器等。 ----------------
Xwork概况 XWork是一个标准的Command模式实现,并且完全从web层脱离出来.Xwork提供了很多核心功能:前端拦截机(interceptor),运行时表单属性验证,类型转换,强大的表达式 ...
随机推荐
- Unity给力插件之MeshBaker
这是一个用来合并网格.材质.贴图的插件. 其实网上也有一些比较详细的使用说明,但是真实操作起来时,总是有一些搞不清bug.而且,作为功能比较全的插件,在Unity版本更新时,也难免会一些不兼容的地方. ...
- [洛谷U871]building
题目来源:http://www.luogu.org/problem/show?pid=U871# [题目背景 Background] WOW是BLIZZARD公司开发的一款网络游戏,游戏的背景是处在一 ...
- linux查看服务器型号
dmidecode | grep "Product";
- mysql数据库引擎问题汇总
可以使用mysql> show engines;查看mysql支持何种引擎, 其中default表明该引擎为默认引擎. 在windows下面的mysql引擎默认为InnoDB,linux下的为 ...
- hibernate sql查询
如果你跟我一样比较熟悉SQL,同时不想学习一门新的语言.那么在hibernate中使用Native SQL 查询也是一种不错的方式. 一方面,Native SQL在效率方面有天生的优势: 另一方面,S ...
- jetty-如何配置虚拟主机【转】
jetty-如何配置虚拟主机[转]http://weifly.iteye.com/blog/1152688 官方配置:http://wiki.eclipse.org/Jetty/Howto/Confi ...
- onkeyup 事件会在键盘按键被松开时发生
定义和用法 onkeyup 事件会在键盘按键被松开时发生. 语法 onkeyup="SomeJavaScriptCode" 参数 描述 SomeJavaScriptCode 必需. ...
- 实践javascript美术馆的小案例,学习到的东西还是蛮多的,包括javascript编程中的预留退路、分离javascript、以及实现向后兼容等
javascript美术馆(改进2) 一.javascript编程过程中的好习惯 1.实现预留退路 js被禁掉,图片也可以显示出来,href属性带有图片路径 <script src=" ...
- 我的第一个 Rails 站点:极简优雅的笔记工具-Raysnote
出于公司开发需求,这个暑假我開始搞Ruby on Rails.在业余时间捣鼓了一个在线笔记应用:http://raysnote.com.这是一个极简而优雅的笔记站点(至少我个人这么觉得的). 笔记支持 ...
- Fastjson介绍
简单介绍 Fastjson是一个Java语言编写的高性能功能完好的JSON库. 高性能 fastjson採用独创的算法,将parse的速度提升到极致,超过全部json库,包含以前号称最快的jackso ...