iOS设计模式 - 命令模式

前言:

命令对象封装了如何对目标执行指令的信息,因此客户端或调用者不必了解目标的任何细节,却仍可以对他执行任何已有的操作。通过把请求封装成对象,客 户端可 以把它参数化并置入队列或日志中,也能够支持可撤销操作。命令对象将一个或多个动作绑定到特定的接收器。命令模式消除了作为对象的动作和执行它的接收器之 间的绑定。

正文内容大纲:

1、电视机、遥控器与接收器之间的关系
2、改变一个视图的明暗程度(未使用命令模式)
3、命令模式介绍
4、改变一个视图的明暗程度(使用命令模式)
5、附录


1.电视机、遥控器与接收器之间的关系

电视机没有遥控器当然也能够换台
如果要用遥控器,电视机上面肯定要有红外线接收器,专门用来接受遥控器的信息。
红外线接收器专门接受遥控器的信息,并转化成电视机里面的信息,让电视机识别。

    • 遥控器与接收器并非必要的设备
    • 接收器转换遥控器的信号
    • 电视机、遥控器与接收器之间的关系:电视机可以独立,不用遥控器和红外线接收器


2.改变一个视图的明暗程度的小实例项目(未使用命令模式)

首先在ViewController添加三个按钮,并设置好相关属性和监听点击事件:


然后创建任务执行者对象Receiver类,创建的实例对象负责执行调整View背景明亮暗度


因为在非命令模式下,撤销逻辑不好实现,这里就不提供实现了


最后展示效果:


其实到这里,Receive对象相当于ViewController的代理,代理完成控制属于Viewcontroller管理和控制的View 的背景明亮暗度调整。只不过这个代理不是那么抽象而且也不是遵循了某个协议的。是具体而直接完成逻辑业务的。这个简单的模式,在项目或者不考虑拓展性或者 某个模块功能固定了,可以使用这个模式。

但是有的业务需求会需要记录存储和取出执行任务的或者信息传递命令的状态,像这里如果要添加撤销操作,就需要记录之前的操作,然后根据之前的操作回 退反过来操作,这时候,命令模式就能比较方便的实现这个逻辑了。命令模式其实就是将发送的命令信息抽象成一个类,然后具体信息就创建具体的类,并通过回调 者添加并执行命令对象的执行命令涉及到的任务方法,同时存储记录这个命令,那么这时候因为每次操作都能存储下来,所以再来设计撤销操作就很容易了。这就是 命令模式的一个优点。

3.命令模式介绍

命令模式的UML图:


概述

在软件系统中,“行为请求者”与“行为实现者”通常呈现一种“紧耦合”。但在某些场合,比如要对行为进行“记录、撤销/重做、事务”等处理,
这种无法抵御变化的紧耦合是不合适的。在这种情况下,如何将“行为请求者”与“行为实现者”解耦?将一组行为抽象为对象,实现二者之间
的松耦合。这就是命令模式(Command Pattern)。

4.改变一个视图的明暗程度(使用命令模式)

分析之前的代码:


为了能够行为进行“记录、撤销/重做、事务”等处理,我们可以使用命令模式:

  • 设定接受者
  • 将改变明暗的操作抽象成对象
  • 撤销操作

分析:


最后命令的发起者和命令的执行者是解耦的。

提供更完整的代码链接: http://pan.baidu.com/s/1sjOlm8l 密码: me5f

5、附录

IOS命令模式的学习网站:http://www.cnblogs.com/YouXianMing/p/4888402.html

大神项目源码编程细节学习积累,所谓编程经验就是在实际代码应用中,代码的用法,代码的风格,代码表述逻辑的方式,分析和积累真正的有几年开发经验的大神写的代码,可以让你更快的提高编程经验值:

使用枚举设置控件的Tag值:


画控件的边框属性:


命令模式的代码细节:



用内置的函数设置MIN和MAX的边界,个人觉得在这里是多余的,不过这两个函数的用法可以积累下来,用于其他需要的时候使用。


学习的编程细节方面的技巧:


空引用和空方法:

时间: 2024-10-29 01:44:36

iOS设计模式 - 命令模式的相关文章

iOS设计模式 - 命令

iOS设计模式 - 命令   原理图   说明 命令对象封装了如何对目标执行指令的信息,因此客户端或调用者不必了解目标的任何细节,却仍可以对他执行任何已有的操作.通过把请求封装成对象,客户端可以把它参数化并置入队列或日志中,也能够支持可撤销操作.命令对象将一个或多个动作绑定到特定的接收器.命令模式消除了作为对象的动作和执行它的接收器之间的绑定.   源码 https://github.com/YouXianMing/iOS-Design-Patterns // // Invoker.h // C

解读设计模式----命令模式(Command Pattern)

本文与作者原文有一定的偏差,其中加入了一部分是个人看法,详细请查看作者原文.*** 原文连接http://www.dofactory.com/Patterns/PatternCommand.aspx 命令模式意图: GOF 在<设计模式>一书中阐述其意图:"将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化:对请求排队或记录请求日志,以及支持可取消的操作."这里所谓的"不同的请求"也既意味着请求可能发生的变化,是一个可能扩展的功能点. 命令

[Head First设计模式]餐馆中的设计模式——命令模式

系列文章 [Head First设计模式]山西面馆中的设计模式--装饰者模式 [Head First设计模式]山西面馆中的设计模式--观察者模式 [Head First设计模式]山西面馆中的设计模式--建造者模式 [Head First设计模式]饺子馆(冬至)中的设计模式--工厂模式 [Head First设计模式]一个人的平安夜--单例模式 [Head First设计模式]抢票中的设计模式--代理模式 [Head First设计模式]面向对象的3特征5原则 [Head First设计模式]鸭子

经典设计模式——命令模式

    考虑这样一种场景,某个方法需要完成某一个功能,完成这个功能的大部分步骤已经确定了,但可能有少量具体步骤无法确定,必须等到该方法执行时才可以确定.具体一点:假设有个方法需要遍历某个数组的数组元素,但无法确定在遍历数组元素时如何处理这些元素,需要调用该方法时指定具体的处理行为.这个要求看起来有点奇怪:这个方法不仅要求传入参数可以变化,甚至要求方法执行体的代码也可以变化,难道我们能把"处理行为"作为一个参数传入该方法?     很遗憾,Java语言暂时还不支持将代码块作为参数传递给方

PHP设计模式——命令模式

声明:本系列博客参考资料<大话设计模式>,作者程杰.             命令模式:在软件系统中,"行为请求者"与"行为实现者"通常呈现一种"紧耦合".但在某些场合,比如要对行为进行"记录.撤销/重做.事务"等处理,这种无法抵御变化的紧耦合是不合适的.在这种情况下,如何将"行为请求者"与"行为实现者"解耦?将一组行为抽象为对象,实现二者之间的松耦合.这就是命令模式.  

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

命令模式(Command Pattern) --.NET设计模式系列之十七 TerryLee,2006年7月 概述 在软件系统中,"行为请求者"与"行为实现者"通常呈现一种"紧耦合".但在某些场合,比如要对行为进行"记录.撤销/重做.事务"等处理,这种无法抵御变化的紧耦合是不合适的.在这种情况下,如何将"行为请求者"与"行为实现者"解耦?将一组行为抽象为对象,可以实现二者之间的松耦合[李

14、Python与设计模式--命令模式

一.饭店点餐系统 又是一个点餐系统(原谅作者的吃货属性).不过这次的点餐系统是个饭店的点餐系统.饭店的点餐系统有什么不同嘛?大伙想想看,在大多数饭店中,当服务员已经接到顾客的点单,录入到系统中后,根据不同的菜品,会有不同的后台反应.比如,饭店有凉菜间.热菜间.主食间,那当服务员将菜品录入到系统中后,凉菜间会打印出顾客所点的凉菜条目,热菜间会打印出顾客所点的热菜条目,主食间会打印出主食条目.那这个系统的后台模式该如何设计?当然,直接在场景代码中加if-else-语句判断是个方法,可这样做又一次加重

Java设计模式--命令模式

命令模式(别名:动作,事物) 为系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. Command Pattern(Another name:Action,Transaction) Encapsulate a request as an object, thereby letting you parameterize clients with different requests, queue or log requests, and s

设计模式之禅之设计模式-命令模式

一:命令模式的定义        --->命令模式是一个高内聚的模式        --->将一个请求封装成一个对象,从而让你使用不同的请求把客户端参数化,对请求排队或者记录请求日志,可以提供命令的撤销和恢复功能.        --->命令模式的角色                ● Receive接收者角色==>该角色就是干活的角色,命令传递到这里是应该被执行的                ● Command命令角色==>需要执行的所有命令都在这里声明