Command命令模式
作用:将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可撤销的操作。

由于“行为请求者”与“行为实现者”的紧耦合,使用命令模式,可以对请求排队或记录请求日志,以及支持可撤销的操作。

UML图:


Command类,用来声明执行操作的接口

ConcreteCommand,将一个接收者对象绑定于一个操作,调用接收者相应的操作,以实现Execute

Invoker类,要求该命令执行这个请求

Receiver类,知道如何实施与执行一个与请求相关的操作,任何类都可能作为一个接收者。

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

Command模式结构图中,将请求的接收者(处理者)放到Command的具体子类ConcreteCommand中,当请求到来时(Invoker发出Invoke消息激活Command对象),ConcreteCommand将处理请求交给Receiver对象进行处理。

命令模式的优点:
1,它能较容易地设计一个命令队列;
2,在需要的情况下,可以较容易地将命令记入日志;
3,允许接收请求的一方决定是否要否决请求。
4,可以容易地实现对请求的撤销和重做;
5,由于加进新的具体命令类不影响其他的类,因此增加新的具体命令类很容易。

命令模式把请求一个操作的对象与知道怎么执行一个操作的对象分割开。

Command模式关键就是讲一个请求封装到一个类中(Command),再提供处理对象(Receiver),最后Command命令由Invoker激活。另外,我们可以将请求接收者的处理抽象出来作为参数传给Command对象,实际也就是回调的机制来实现这一点。也就是讲处理操作方法地址通过参数传递给Command对象,Command对象在适当的时候再调用该函数。

Command模式将调用操作的对象和知道如何实现该操作的对象解耦,在上面Command的结构图中,Invoker对象根本就不知道具体的是哪个对象在处理Execute操作(当然要知道是Command类别的对象)。
在Command要增加新的处理操作对象很容易,我们可以通过创建新的继承自Command的子类来实现这一点。
Command模式可以和Memento模式结合起来,支持取消的操作。

代码如下:

Command.h

 #ifndef _COMMAND_H_
#define _COMMAND_H_ class Command
{
public:
virtual ~Command();
virtual void Execute()=;
protected:
Command();
private:
}; class Receiver; class ConcreteCommand : public Command
{
public:
ConcreteCommand(Receiver* pReceiver);
~ConcreteCommand();
virtual void Execute();
protected:
private:
Receiver* _recv;
}; class Invoker
{
public:
Invoker(Command* pCommand);
~Invoker();
void Invoke();
protected:
private:
Command* _cmd;
}; class Receiver
{
public:
Receiver();
~Receiver();
void Action();
protected:
private:
};
#endif

Command.cpp

 #include "Command.h"
#include <iostream> using namespace std; Command::Command()
{} Command::~Command()
{} ConcreteCommand::ConcreteCommand(Receiver* pReceiver)
{
this->_recv = pReceiver;
} ConcreteCommand::~ConcreteCommand()
{} void ConcreteCommand::Execute()
{
this->_recv->Action();
} Receiver::Receiver()
{} Receiver::~Receiver()
{} void Receiver::Action()
{
cout << "Receiver::Action" << endl;
} Invoker::Invoker(Command* pCommand)
{
this->_cmd = pCommand;
} Invoker::~Invoker()
{} void Invoker::Invoke()
{
this->_cmd->Execute();
}

main.cpp

 #include "Command.h"

 int main()
{
//创建具体命令对象pCmd并设定它的接收者pRev
Receiver* pRev = new Receiver();
Command* pCmd = new ConcreteCommand(pRev);
//请求绑定命令
Invoker* pInv = new Invoker(pCmd);
pInv->Invoke(); return ;
}

最新文章

  1. hdu 1342(DFS)
  2. WPF仿Win7便笺
  3. 解密 JavaScript 中的 this
  4. 14 接口-interface的定义与实现
  5. Unity3D游戏制作(四)——Asset Server搭建
  6. 斯坦福第十六课:推荐系统(Recommender Systems)
  7. BZOJ2093 : [Poi2010]Frog
  8. 关于conversation generation的论文笔记
  9. 51nod1119 机器人走方格 V2
  10. androisd wifi
  11. spart快速大数据分析学习提纲(一)
  12. Thread Join()的用法
  13. Android项目中gen文件下R文件无法生成的解决的方法
  14. 性能测试培训:定位jvm耗时函数
  15. find与tar的结合使用
  16. linux修改TCP最大连接数
  17. DokuWiki的发现之旅
  18. Mysql数据库账户权限设置
  19. 无视编码都统一转成unicode 然后截断 例如 。“发发发发发发” 操作之后显示为 “发发发发...”
  20. Java中的List集合和迭代器

热门文章

  1. 前端学习 第四弹: HTML(一)
  2. 酷炫ILOVEU
  3. 实现DevExpress GridControl 只有鼠标双击后才进行修改数据
  4. 【python】多进程锁multiprocess.Lock
  5. 反人类的java
  6. webpack的几个使用方法
  7. 关于QFTP乱码
  8. java获取图片原始尺寸
  9. NAT 网络地址转换
  10. css3基础、(弹性、响应式)布局注意点