Command设计模式
1 意图:将一个请求封装为一个对象,可以用不同的请求对客户进行参数化;
对请求排队或记录请求日志,以及支持可撤销的操作。
2 别名:Action、Transaction
3 动机:把请求变成一个对象。关键是定义一个抽象的Command类,定义一个执行操作的接口。最简单有一个抽象的Execute操作。
具体的Command子类将接收者作为一个实例变量,实现Execute,指定接收者采取的动作。
有时需要执行一系列的命令,定义一个MacroCommand来执行任意数目的命令。序列中的命令各自定义接收者。
注意:Command怎样解耦“调用操作的对象”和“具有执行该操作所需要信息的那个对象”。
动态替换Command对象
4 适用性:
.抽象出待执行的动作用来参数化某对象。可以用Callback实现。
回调函数是指,先在某处注册,在稍后某个需要的时候被调用。
Command模式是回调函数的一个面向对象的替代品。
.在不同时刻指定、排列和执行请求。一个Command对象可以有一个与初始请求无关的生存期。
如果一个请求的接收者可用一种与地址空间无关的方式表达, 那么可将负责该请求的命令对象传送给另一个不同的进程并在那儿实现该请求。
.支持取消操作,Execute前,保存执行前的操作状态,这些修改可以被重做一遍。Command添加UnExecute操作
.支持修改日志,当系统崩溃时,修改可被重做一遍。需要添加装载操作和存储操作
.用构建在原语操作上的高层操作构造一个系统。支持事务。
5 参与者:
Command:声明执行操作的接口
ConcreteCommand:将一个接收者对象绑定于一个动作。调用接收者相应的操作实现Execute
Client:创建一个具体命令对象并设定它的接收者。
Invoker:要求该命令执行这个请求。
Receiver:知道如何实施与执行一个请求相关的操作。任何类都肯恩作为一个接收者。
6 协作:
.客户创建一个ConcreteCommand并制定它的Receiver对象
.Invoker对象存储该ConcreteCommand对象
.Invoker通过调用Command对象的Execute操作提交一个请求。
命令是可撤销的,ConcreteCommand就在执行Execute操作之前存储当前状态以用于取消命令
.ConcreteCommand对象对调用它的Receiver的一些操作以执行该请求
7 效果:
.将调用对象的操作与知道如何实现该操作的对象解耦
.Command是头等的对象。可以扩展
.将多个命令装配成一个符合命令。MacroCommand。一般,复合命令是Composite的一个实例
.增加新的Command很容易
8 实现:
1)一个命令对象应达到何种智能程度
一个极端:仅确定该请求的接收者和执行该请求的操作
另一个极端:自己实现所有功能,不要额外的接收者对象
2)支持取消和重做操作
ComcreteCommand需要额外存储状态信息。
这个状态包括:
.接收者对象,真正执行处理该请求的各操作
.接收者上执行该操作的参数
.如果接收者的某些值被改变了,需要先保存起来。
要支持多级取消重做,需要历史列表。Command对象在各次调用之间的状态如果变化,需要拷贝命令对象,以区分相同命令的不同调用。
如果状态不变就不需要拷贝,这些必须背靠背的Command对象起着原型的作用
3)避免取消操作过程中的错误累积
Memento模式使得Command访问这些信息不暴露其他对象的内部状态
4)使用C++模板
对不能被取消,不需要参数的命令。避免为每一种动作和接收者都创建一个Command子类
9 相关命令:
.Composite模式可被用来实现宏命令
.Memento模式保持某个状态
还有Prototype
Command设计模式的更多相关文章
- Java 设计模式之 Command 设计模式
首先我们先来看 UML 图: 参考资料: java设计模式-Command(命令)模式 - - ITeye技术网站http://men4661273.iteye.com/blog/1633775 JA ...
- 详解command设计模式,解耦操作和回滚
大家好,欢迎来到设计模式专题,我们的主旨是介绍一些有趣好玩的设计模式. 今天我们介绍的设计模式叫做命令模式(command),在这个模式下,我们可以实现do和undo的解耦,让使用方不用关心内部的实现 ...
- 《C++设计新思维》Command设计模式读后感
原文内容提领: 本书第5章标题为泛化仿函数,我认为本章真正讲述的内容可以总结出一句话! 如何利用C++老标准实现C++11新标准类似std::function提供的功能. std::function简 ...
- [学习笔记]设计模式之Command
为方便读者,本文已添加至索引: 设计模式 学习笔记索引 写在前面 在上篇Chain of Responsibility(职责链)模式笔记中,我们学习了一种行为型设计模式.今天,我们继续这一主题,来学习 ...
- Command模式(命令设计模式)
Command?? 把方法的调用用一个类的实例来承载,要管理工作的历史记录,创建这些方法执行的命令的集合,只需管理这些实例的集合即可,而且还可以随时再次执行过去的命令,或是将多个过去的命令整合为一个新 ...
- Swift语言之命令模式(Command Pattern)实现
今天遇到这样一个问题,我现在有一个整数数组,如: var numbers = [3, 7, 12, 9, 200] 现需要对其中的每一个数字都执行一系列相同的加减乘除操作,如对每一个数字都加5乘8再减 ...
- (Command Pattern)命令模式
定义 将“请求”封装成对象,以便使用不同的请求.队列或者日志来参数化其他对象.命令模式也支持可撤销的操作. 结构图: 命令模式的角色划分: Reciever(命令的接收者):接收命令,并知道如何进行必 ...
- Struts2 拦截器配置以及实现
@(Java ThirdParty)[Struts|Interceptor] Struts2 拦截器配置以及实现 Struts2的拦截器应用于Action,可以在执行Action的方法之前,之后或者两 ...
- VTK的学习资源
本文介绍从哪儿开始学习VTK(Visualization Toolkit的简称),如何在网上找寻VTK的学习资源. 首先,可以到维基百科或者百度百科上查看VTK条目,了解VTK是什么. http:// ...
随机推荐
- Unity脚本在层级面板中的执行顺序测试4-附加整理
测试4为一些附加内容,后续的各种tips都加在此. 前几篇测试的链接: Unity脚本在层级面板中的执行顺序测试1 http://www.cnblogs.com/hont/p/4298110.html ...
- CSUFT 1002 Robot Navigation
1002: Robot Navigation Time Limit: 1 Sec Memory Limit: 128 MB Submit: 4 Solved: 2 Descript ...
- Oracle之ORA-00972: identifier is too long
一.前言 今天在程序的日志中出现这个错误,网上搜了一下发现,说是Oracle的对象名字最多是30个字符,不能超过30,而我出错的sql是: "select * from test where ...
- asp.net OnInit、OnLoad、Page_Load、Page_Init父子页面执行顺序探究
本次探究page页面加载的时候,它们的执行顺序 BasePage public class BasePage : Page { public string BaseName { get; set; } ...
- 2016年10月17日 星期一 --出埃及记 Exodus 19:1
2016年10月17日 星期一 --出埃及记 Exodus 19:1 In the third month after the Israelites left Egypt--on the very d ...
- centOS安装Mysql指南
centOS安装Mysql指南 说明:使用操作系统centOS6.4 32位系统:mysql:mysql-5.7.10-linux-glibc2.5-i686.tar.gz; 一.准备 下载mysql ...
- SqlSever基础 两个条件 group by 分组显示
镇场诗:---大梦谁觉,水月中建博客.百千磨难,才知世事无常.---今持佛语,技术无量愿学.愿尽所学,铸一良心博客.------------------------------------------ ...
- SqlSever基础 union all 联合查询,简单的组合 两个查询结果拼在一起
镇场诗:---大梦谁觉,水月中建博客.百千磨难,才知世事无常.---今持佛语,技术无量愿学.愿尽所学,铸一良心博客.------------------------------------------ ...
- Dev gridview新增一行自动获得焦点并打开编辑模式
1.gridview添加一行自动获得焦点实现方式: 关键代码: GarsonZhang dt.Rows.Add("1", "2"); gridView1.Foc ...
- Java_GC详解
Java -- GC 标签(空格分隔): Java 要想深入了解Java的GC(Garbage Collection),我们应该先探寻如下三个问题: What? -- 哪些内存需要回收? When? ...