Command(命令)–对象行为型模式

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

二、动机
1.在软件构建过程中,“行为请求者”与“行为实现者”通常呈现一种“紧耦合”。但在某些场合——比如需要对行为进行“记录、撤销、重做(undo、redo)、事物”等处理,这种无法抵御变化的紧耦合是不合适的。
2.在这种情况下,如何将“行为请求者”与“行为实现者”解耦?将一组行为抽象为对象,可以实现二者之间的松耦合。

三、适用性
1.抽象出待执行的动作以参数化某对象。你可用过程语言中的回调(callback)函数表达这种参数化机制。Command模式是回调机制的一个面向对象的替代品。
2.在不同的时刻指定、排列和执行请求。一个Command对象可以有一个与初试请求无关的生存期。如果一个请求的接受者可用一种与地址空间无关的方式表达,那么就可将负责该请求的命令对象传递给另一个不同的进程并在那儿实现该请求。
3.支持取消操作。Command的Execute操作可子啊实施操作前将状态存储起来,在取消操作时这个状态用来消除该操作的影响。Command接口必须添加一个Unexecute操作,该操作取消上一次Execute调用的效果。执行的命令被存储子啊一个历史列表中。可通过向后和向前遍历者一列表并分别调用Unexecute和Execute来实现重数不限的“取消”和“重做”。
4.支持修改日志,这样当系统奔溃时,这些修改可用被重做一遍。在Command接口中添加装载操作和存储操作,可以用来保持变动的一个一致的修改日志。从奔溃中恢复的过程包括从磁盘中重新读入记录下来的命令并用Execute操作重新执行它们。
5.用构建在原语操作上的高层操作构造一个系统。这样一种结构在支持事务的信息系统中很常见。一个事务封装了对数据的一组变动。Command模式提供了对事务进行建模的方法。Command有一个公共的接口,使得你可以用同一种方式调用所有的事务。同时使用该模式也易于添加新的事务以扩展系统。

四、结构

五、效果
1.Command模式将调用操作的对象与知道如何实现该操作的对象解耦。
2.Command是头等的对象。它们可像其他的对象一样被操作和扩展。
3.你可将多个命令装配成一个复合命令。
4.增加新的Command很容易,因为这无需改变已有的类。

六、实现
1.一个命令对象应达到何种智能程度。
2.支持取消(undo)和重做(redo)。
3.避免取消操作过程中的错误积累。
4.使用C++模版。

七、要点总结
1.Command模式的根本目的在于将“行为请求者”与“行为实现者”解耦,在面向对象的语言中,常见的实现手段是“将行为抽象为对象”。
2.实现Command接口的具体命令对象ConcreteCommand有时候根据需要可能会保存一些额外的状态信息。通过使用Composite模式,可以将多个“命令”封装为一个“复合命令”。
3.Command模式与C++中的函数对象有些类似。但两者的定义行为接口的规范有所区别:Command以面向对象中的“接口-实现”来定义行为接口规范,更严格,但有性能损失;C++函数对象以函数签名来定义行为接口规范,更灵活,性能更高。

八、相关模式
Composite模式可被用来实现宏命令。
Memento模式可用来保持某个状态,命令用这一状态来取消它的效果。
在被放入历史表列前必须被拷贝的命令起到一种原型的作用。

九、举例说明
命令模式类似于消息。

本文为李建忠设计模式视频的笔记以及《设计模式-可复用面向对象的软件的基础》和自己的部分见解

Command(命令)--对象行为型模式相关推荐

  1. Memento(备忘录)--对象行为型模式

    Memento(备忘录)–对象行为型模式 一.意图 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保持这个状态.这样以后就可将该对象恢复到原先保存的状态. 二.动机 1.在软件构建过程 ...

  2. Typescript玩转设计模式 之 对象行为型模式(上)

    作者简介 joey 蚂蚁金服·数据体验技术团队 继前面几篇设计模式文章之后,这篇介绍5个对象行为型设计模式. Chain of Responsibility(职责链) 意图 使多个对象都有机会处理请求 ...

  3. 设计模式-对象行为型模式

    [对象行为型模式]涉及到算法和对象间职责的分配,描述了对象和类的模式,以及它们之间的通信模式. 用来对类或对象怎样交互和怎样分配职责进行描述 1.  策略模式(strategy)           ...

  4. 2018.3.31 设计模式之生成器模式详解及例子(对象创建型模式)

    设计模式之生成器模式(对象创建型模式) 1.定义/概念 将一个复杂对象的创建和它的表示分离,使得同样的创建过程可以有不同的表示. 2.生成模式角色 Builder: 生成器接口,定义创建一个Produ ...

  5. Visitor(访问者)--对象行为型模式

    Visitor(访问者)–对象行为型模式 一.意图 表示一个作用于某个对象结构中的各元素的操作.它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作. 二.动机 1.在软件构建过程中,由于需 ...

  6. Strategy(策略)--对象行为型模式

    Strategy(策略)–对象行为型模式 一.意图 定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换.本模式使得算法可独立于使用它的客户而变化. 二.动机 1.在软件构建过程中,某些对象使 ...

  7. State(状态)--对象行为型模式

    State(状态)–对象行为型模式 一.意图 允许一个对象在其内部状态改变时改变它的行为.对象看起来似乎修改了它的类. 二.动机 1.在软件构建过程中,某些对象的状态如果改变,其行为也会随之而发生变化 ...

  8. Observer(观察者)--对象行为型模式

    Observer(观察者)–对象行为型模式 一.意图 定义对象间的一种一对多的依赖关系,当一个对象的状态发生变化时,所有的依赖于它的对象都得到通知并被自动更新. 二.动机 1.在软件构建过程中,我们需 ...

  9. Mediator(中介者)--对象行为型模式

    Mediator(中介者)–对象行为型模式 一.意图 用一个中介对象来封装一系列的对象交互.中介者使各对象不需要显示地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 二.动机 1.在软 ...

最新文章

  1. 【数据库】SQL极速入门(多种方式查询用户复借次数)
  2. 传统企业建模原理及建模体系介绍
  3. 数据中心主机房的加湿量和除湿量如何计算
  4. 【快乐水题】709. 转换成小写字母
  5. 欢迎报名参加第四届亚洲信息获取暑期学校(ASSIA2019)
  6. MySQL -> ES 数据同步 配置步骤
  7. android学习之旅-学习计划
  8. 连接maven_如何在Eclipse中使用Maven工程连接远程的Spark
  9. CPU:别再拿我当搬砖工!
  10. vba上传文件到ftp服务器指定目录下面
  11. Write a simple HTML Browser(hdu1088)
  12. nginx 后端获取真实ip
  13. padding、margin百分比
  14. C++语言动态内存管理介绍和示例
  15. 计算机网络 校园网规划,计算机网络课程校园网规划设计
  16. Reloading Java Classes 101: Objects, Classes and ClassLoaders Translation
  17. matlab struct 结构体
  18. Java小游戏的音乐播放
  19. 购买周期 python-用Python实现一个基于EG协整法的跨周期套利策略
  20. 计算机软考初级工程资料,计算机软考数据库系统工程师考前练习300资料.doc

热门文章

  1. C语言试题八十四之求空间两点之间的距离
  2. 动态规划之两个字符串的最大子序列
  3. 一套完整的导视设计案例_色彩导视艺术:乌克兰基辅语言学校导视设计案例
  4. html点击关闭代码,怎样开放和关闭html代码?
  5. 女孩看男孩VS男孩看女孩
  6. 每个女孩子起床后做的第一件事......
  7. 史上最难逻辑题!据说99.9%的人都做不出来……
  8. 不懂物理,何以谈科技?
  9. 国外的程序猿可以工作到退休而国内的为什么这么短命(思维认知)
  10. 用画小狗的方法来解释Java中的值传递