查看原文
其他

我们常用的撤销和恢复功能,你知道它们使用了什么设计模式吗?

程序猿DD 2020-10-16

点击上方蓝色“程序猿DD”,选择“设为星标”

回复“资源”获取独家整理的学习资料!

作者 | 滴水微澜

来源 | cnblogs.com/zhou--fei/p/9905536.html

现有场景描述:

现在无论是系统自带的键盘还是第三方的键盘一般都自带撤销和恢复功能,你知道它们是用的什么模式实现的吗?

它们用的是命令模式 + 观察者模式,你答对了吗?

简单科普一下

啥是命令模式(Command)

Command模式:

  • 模式类型:行为类模式

  • 定义:将一个操作、一个方法调用、一个命令封装成一个对象,在合适的时候让这个对象进行执行。

  • 适用场景(执行意愿):像个皇帝身边的守护侍卫一样,随叫随到。随时准备着等待被调用。例如:软件提供的菜单按钮,点击了,就会执行相应的操作。

  • 类图:

调用者中有个聚合关系的命令类

命令类索引着命令接受者

是不是So Easy!!

啥是观察者(Obsevser)模式?

  • 模式类型:行为类模式

  • 定义:表示的是一种一对多的关系。当被观察者类A的属性aa发生了改变,就会主动去通知观察类B、C、D,这样观察类们的状态就会及时的被更新了。

  • 适用场景(执行意愿):控制器观察model中的属性,当属性变化了就去更新View的信息。系统时刻观察者键盘的字符输入,有了输入时,就把输入信息通知给View展示。等等。

  • 类图:

被观察者索引着观察者对象

是不是So Easy!!

关于观察者模式,如果有不熟悉的童鞋,看这里,加代码具体来讲解:设计模式是什么鬼(观察者)

Cocoa Touch框架内的实际应用

NSUndoManager是苹果提供的撤销恢复管理类,它里面主要有三个要素构成

  • 恢复栈
  • 撤销栈
  • 命令对象:NSInvocation

图表显示如下:

进入撤销栈时,NSInvocation执行撤销命令

进入恢复栈时,NSInvocation执行恢复命令

开发中如何将它们合起来用呢?

  1. 在Command中添加命令执行对象NSInvocation
  2. 在Command中添加观察者列表,当命令执行是通知列表中的观察者
  3. 创建一个类似NSUndoManager的类,来管理整体commond列表


往期推荐

后端必备:15000 字的 SQL 语句大全

IntelliJ IDEA团队开始在中国招人了

Serverless 初体验:快速开发与部署一个Hello World

短信验证码登录的实现流程

老司机给我们解读 Spring Boot 最流行的 16 条忠告


我们在星球聊了很多深度话题,你不来看看?

我的星球是否适合你?

点击阅读原文看看我们都聊过啥?

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存