//---------------------------15/04/25----------------------------

//Conmmand  命令模式----对象行为型模式

/*

1:意图:

将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,

以及支持可撤销的操作。

2:别名:

Action,Transaction(事务)

3:动机:

4:适用性:

1>抽象出待执行的动作以参数化某对象。可以使用回调函数表达这种参数化机制。

也就是说,Conmmand模式是回调机制的一个面向对象的代替品。

2>在不同的时刻指定、排列和执行请求。一个Conmmand对象可以有一个与初始请求无关的生存期。

如果请求的接收者可以用一种与地址空间无关的方式表达,那么就可以将负责该请求的命令对象

传送给另一个不同的进程,并在那儿实现该请求。

3>支持取消操作。执行操作后,可以调用一个接口来取消操作。

4>支持修改日志,这样当系统崩溃时,这些修改可以被重做一遍。

5>用构建在原语操作上的高层操作构造一个系统。

5:结构:

Client               Invoker------->Command:

|  |                               Execute()

|                                   |

|  |                               ConcreteCommand:

|------->Receiver:<-------------receiver

|           Action()               Execute()

{ receiver->Action();}

|- - - - - - - - - - - - - - - - ->state

6:参与者:

1>Command:

声明执行操作的接口。

2>ConcreteCommand

1)将一个接收者对象绑定于一个动作。

2)调用接收者相应的操作,以实现Execute。

3>Client

创建一个具体命令对象并设定它的接受者。

4>Invoker

要求该命令执行这个请求。

5>Receiver

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

7:协作:

1>Client创建一个ConcreteCommand对象并指定它的Receiver对象。

2>某Invoker对象存储该ConcreteCommand对象。

3>该Invoker通过调用Conmmand对象的Execute操作来提交一个请求。若该命令时可撤销的,

ConcreteCommand就在执行Execute操作之前存储当前状态以用于取消该命令。

4>ConcreteCommand对象调用它的Receiver的一些操作以执行该请求。

8:效果:

1>Command模式将调用操作的对象与指导如何实现该操作的对象解耦。

2>Command是头等的对象。它们可以像其他的对象一样被操作和扩展。

3>你可讲多个命令装配成一个复合命令。

4>增加新的Command很容易,因为这无需改变已有的类。

9:实现:

1>一个命令对象应达到何种智能程度:

命令对象的能力可大可小。一个极端是只确定接收者和执行该请求的动作。另一个极端是自己

实现所有功能,根本不需要额外的接收者对象。(这样就退化成策略模式了)

2>支持取消和重做

如果Command提供方法逆转他们操作的执行(例如Unexecute或Undo操作),就可以支持取消和重做

功能。为了达到这个目的ConcreteCommand类需要存储额外的状态信息:

1)接收者对象,它真正执行处理该请求的各操作。

2)接收者执行操作的参数。

3)如果处理请求的操作会改变接收者对象中的某些值,那么这些值夜必须先存储起来。接收者

还必须提供一些操作,以使该命令可将接收者恢复到它先前的状态。

3>避免取消操作过程中的错误积累

使用Menmento模式来让Command访问信息时不暴露其他对象的内部信息。

4>使用C++模版


不能取消 并且
不需要参数的命令,可以使用C++模版实现,这样可以避免为每一种动作和接收者

都创建一个Command子类。

10:代码示例:                                                                        */

//abstract Command类

class Command

{

public:

virtual ~Command();

virtual void Execute() =
;

protected:

Command();

};

//ConcreteCommand:

class OpenCommand :
public Command

{

public:

OpenCommand(Application*);

virtual void Execute();

protected:

virtual const
char* AskUser();

private:

Application* _application;

char* _response;

};

OpenCommand::OpenCommand(Application* a)

{

_application = a;

}

//先请求一个名字,然后添加文件,然后打开之

void OpenCommand::Execute()

{

const char* name = AskUser();

)

{

Document* document =
new Document(name);

_application->Add(document);

document->Open();

}

}

//ConcreteCommand:

class PasteCommand :
public Command

{

public:

PasteCommand(Document*);

virtual void Execute();

private:

Document* _document;

};

PasteCommand::PasteCommand(Document* doc)

{

_document = doc;

}

void PasteCommand::Execute()

{

_document->Paste();

}

//ConcreteCommand:通过模版实现,避免多余的子类。

template<class Receiver>

class SimpleCommand :
public Command

{

public:

//创建一个别名:这是一个函数指针,一个参数为空,返回为空的Receiver类的成员函数指针

//也是因为这个命令不需要参数,所以可以声明成模版类。

typedef void (Receiver::* Action)();

SimpleCommand(Receiver* r, Action a): _receiver(r), _action(a){}

virtual void Execute();

private:

Action _action;

Receiver* _receiver;

};

template<class Receiver>

void SimpleCommand<Receiver>::Execute()

{

(_receiver->*_action)();

}

MyClass* Receiver =
new MyClass;

//...

Command* aCommand =
new SimpleCommand<MyClass>(receiver, &MyClass::Action);

//...

aCommand->Execute();

//ConcreteCommand:一次执行多条命令的复合命令

class MarroCommand :
public Command

{

public:

MarroCommand();

virtual ~MarroCommand();

virtual void Add(Command*);

virtual void Remove(Command*);

virtual void Execute();

private:

List<Command*>* _cmds;

};

void MarroCommand::Execute()

{

ListIterator<Command*> i(_cmds);

for(i.First(); !i.IsDone(); i.Next())

{

Command* c = i.CurrentItem();

c->Execute();

}

}

void MarroCommand::Add(Command* c)

{

_cmds->Append(c);

}

void MarroCommand::Remove(Command* c)

{

_cmds->Remove(c);

}

设计模式 笔记 命令模式 Command的更多相关文章

  1. 设计模式 ( 十三 ) 命令模式Command(对象行为型)

    设计模式 ( 十三 ) 命令模式Command(对象行为型) 1.概述         在软件设计中,我们经常需要向某些对象发送请求,但是并不知道请求的接收者是谁,也不知道被请求的操作是哪个,我们只需 ...

  2. 乐在其中设计模式(C#) - 命令模式(Command Pattern)

    原文:乐在其中设计模式(C#) - 命令模式(Command Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 命令模式(Command Pattern) 作者:webabcd ...

  3. 面向对象设计模式_命令模式(Command)解读

    在.Net框架中很多对象的方法中都会有Invoke方法,这种方法的设计实际是用了设计模式的命令模式, 模式图如下 其核心思路是将Client 向Receiver发送的命令行为进行抽象(ICommand ...

  4. 二十四种设计模式:命令模式(Command Pattern)

    命令模式(Command Pattern) 介绍将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化:对请求排队或记录请求日志,以及支持可取消的操作. 示例有一个Message实体类,某个 ...

  5. 设计模式-15命令模式(Command Pattern)

    1.模式动机 在软件设计中,我们经常需要向某些对象发送请求,但是并不知道请求的接收者是谁,也不知道被请求的操作是哪个,我们只需在程序运行时指定具体的请求接收者即可,此时,可以使用命令模式来进行设计,使 ...

  6. [设计模式] 14 命令模式 Command

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

  7. 设计模式之命令模式(Command)摘录

    23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于怎样创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而 ...

  8. 大熊君说说JS与设计模式之------命令模式Command

    一,总体概要 1,笔者浅谈 日常生活中,我们在看电视的时候,通过遥控器选择我们喜欢的频道时,此时我们就是客户端的角色,遥控器的按钮相当于客户请求,而具体执行的对象就是命令对象, 命令模式把一个请求或者 ...

  9. [Head First设计模式笔记]----命令模式

    命令模式定义:将“请求”封装成对象,以便使用不同的请求.队列或者日志来参数化其他对象.命令模式也支持可撤销的操作. 类图: 适用设计方案举例:实现一种遥控器,该遥控器具有七个可编程的插槽(每个都可以指 ...

随机推荐

  1. SELECT查询结果集INSERT到数据表

    简介 将查询语句查询的结果集作为数据插入到数据表中. 一.通过INSERT SELECT语句形式向表中添加数据 例如,创建一张新表AddressList来存储班级学生的通讯录信息,然后这些信息恰好存在 ...

  2. Linux每日小技巧---统计服务器IP连接数

    netstat命令 [root@:vg_adn_tidbCkhsTest:172.31.30.62 ~]#netstat -tun | awk '{print $5}' | cut -d: -f1 | ...

  3. SSL/TLS Diffie-Hellman Modulus <= 1024 位 (LogJam) 使用2048位或更高的Diffie-Hellman

    1.http://slproweb.com/products/Win32OpenSSL.html  下载 SSL 并安装 2.设置环境变量,例如工具安装在C:\OpenSSL-Win64,则将C:\O ...

  4. CSP vs Actor Go vs Erlang

    源于从Erlang到Go的一些思维碰撞,就像当初从C++到Erlang一样,整理下来记于此. Actor Actor模型,又叫参与者模型,其”一切皆参与者(actor)”的理念与面向对象编程的“一切皆 ...

  5. 《python源代码剖析》笔记 python环境初始化

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/zhsenl/article/details/33747209 本文为senlie原创.转载请保留此地 ...

  6. [题目] Luogu P3716 [CTSC2000]冰原探险

    题面 题目背景 传说中,南极有一片广阔的冰原,在冰原下藏有史前文明的遗址.整个冰原被横竖划分成了很多个大小相等的方格.在这个冰原上有N个大小不等的矩形冰山,这些巨大的冰山有着和南极一样古老的历史,每个 ...

  7. ethereum/EIPs-725

    https://github.com/ethereum/EIPs/blob/master/EIPS/eip-725.md eip title author discussions-to status ...

  8. ICSharpCode.SharpZipLib 开源压缩库使用示例

    官方网站:http://www.icsharpcode.net/OpenSource/SharpZipLib/Default.aspx 插件描述: ICSharpCode.SharpZipLib.dl ...

  9. Error at offset之反序列化

    关于PHP 序列化(serialize)和反序列化(unserialize)出现错误(Error at offset)的解决办法. 首先我们分析一下为什么会出现这个错误: 编码问题 UTF-8: AN ...

  10. Docker学习要点记录

    Docker的架构和底层技术: 1.docker提供了一个开发,打包,运行app的平台2.把APP和底层infrastructure隔离开来 docker底层技术支持: 1>Namespaces ...