设计模式之备忘录模式(Memento)摘录
23种GOF设计模式一般分为三大类:创建型模式、结构型模式、行为模式。
Factory Method:定义一个用于创建对象的接口,让子类决定将哪一个类实例化。Factory Method使一个类的实例化延迟到其子类。
Abstract Factory:提供一个创建一系列相关或相互依赖对象的接口,而无需指定他们具体的类。
Singleton:保证一个类仅有一个实例,并提供一个访问它的全局访问点。
Builder:将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。
Prototype:用原型实例指定创建对象的种类,并且通过拷贝这个原型来创建新的对象。
Bridge:将抽象部分与它的实现部分分离,使它们都可以独立地变化。
Adapter:将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。
Decorator:动态地给一个对象添加一些额外的职责。就扩展功能而言, Decorator模式比生成子类方式更为灵活。
Composite:将对象组合成树形结构以表示“部分-整体”的层次结构。Composite使得客户对单个对象和复合对象的使用具有一致性。
Flyweight:运用共享技术有效地支持大量细粒度的对象。
Facade:为子系统中的一组接口提供一个一致的界面, Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
Template Method:定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。Template Method使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
Strategy:定义一系列的算法,把它们一个个封装起来, 并且使它们可相互替换。本模式使得算法的变化可独立于使用它的客户。
State:允许一个对象在其内部状态改变时改变它的行为。对象看起来似乎修改了它所属的类。
Observer:定义对象间的一种一对多的依赖关系,以便当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并自动刷新。
Memento:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到保存的状态。
Mediator:用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
Command:将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可取消的操作。
Visitor:表示一个作用于某对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。
Chain of Responsibility:为解除请求的发送者和接收者之间耦合,而使多个对象都有机会处理这个请求。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它。
Iterator:提供一种方法顺序访问一个聚合对象中各个元素, 而又不需暴露该对象的内部表示。
Interpreter:给定一个语言, 定义它的文法的一种表示,并定义一个解释器, 该解释器使用该表示来解释语言中的句子。
Memento:(1)、意图:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。
(2)、适用性:A、必须保存一个对象在某一个时刻的(部分)状态,这样以后需要时它才能恢复到先前的状态。B、如果一个用接口来让其它对象直接得到这些状态,将会暴露对象的实现细节并破坏对象的封装性。
(4)、相关模式:A、Command:命令可使用备忘录来为可撤销的操作维护状态。B、Iterator:备忘录可用于迭代。
(5)、备忘录模式:适用于功能比较复杂的,但需要记录或维护属性历史的类;或者需要保存的属性只是众多属性中的一小部分时Originator可以根据保存的Memo还原到前一状态。
#include <iostream>
#include <string>using namespace std;class Memo;//发起人类
class Originator
{
public:string state;Memo* CreateMemo();void SetMemo(Memo* memo);void Show(){cout<<"状态"<<state<<endl;}
};//备忘录类
class Memo
{
public:string state;Memo(string strState){state = strState;}
};Memo* Originator::CreateMemo()
{return new Memo(state);
}void Originator::SetMemo(Memo* memo)
{state = memo->state;
}//管理者类
class Caretaker
{
public:Memo* memo;
};//客户端
int main()
{Originator* on = new Originator();on->state = "on";on->Show();Caretaker* c = new Caretaker();c->memo = on->CreateMemo();on->state = "off";on->Show();on->SetMemo(c->memo);on->Show();/*result状态on状态off状态on*/return 0;
}
Memento.h:
#ifndef _MEMENTO_H_
#define _MEMENTO_H_#include <string>using namespace std;class Memento;class Originator
{
public:typedef string State;Originator();Originator(const State& sdt);~Originator();Memento* CreateMemento();void SetMemento(Memento* men);void RestoreToMemento(Memento* mt);State GetState();void SetState(const State& sdt);void PrintState();
protected:
private:State _sdt;Memento* _mt;
};class Memento
{
public:
protected:
private://这是最关键的地方,将Originator为friend类,可以访问内部信息,但是其他类不能访问friend class Originator;typedef string State;Memento();Memento(const State& sdt);~Memento();void SetState(const State& sdt);State GetState();
private:State _sdt;
};#endif//~_MEMENTO_H_
Memento.cpp:
#include "Memento.h"
#include <iostream>using namespace std;typedef string State;Originator::Originator()
{_sdt = "";_mt = 0;
}Originator::Originator(const State& sdt)
{_sdt = sdt;_mt = 0;
}Originator::~Originator()
{}Memento* Originator::CreateMemento()
{return new Memento(_sdt);
}State Originator::GetState()
{return _sdt;
}void Originator::SetState(const State& sdt)
{_sdt = sdt;
}void Originator::PrintState()
{cout<<this->_sdt<<"... ..."<<endl;
}void Originator::SetMemento(Memento* men)
{}void Originator::RestoreToMemento(Memento* mt)
{this->_sdt = mt->GetState();
}//class Memento
Memento::Memento()
{}Memento::Memento(const State& sdt)
{_sdt = sdt;
}State Memento::GetState()
{return _sdt;
}void Memento::SetState(const State& sdt)
{_sdt = sdt;
}
main.cpp:
#include "Memento.h"
#include <iostream>using namespace std;int main()
{Originator* o = new Originator();o->SetState("old");//备忘前状态o->PrintState();Memento* m = o->CreateMemento();//将状态备忘o->SetState("new");//修改状态o->PrintState();o->RestoreToMemento(m);//恢复修改前状态o->PrintState();/*resultold... ...new... ...old... ...*/return 0;
}
备忘录模式结构图:
参考文献:
1、《大话设计模式C++》
2、《设计模式精解----GoF23种设计模式解析》
3、《设计模式----可复用面向对象软件的基础》
设计模式之备忘录模式(Memento)摘录相关推荐
- 二十四种设计模式:备忘录模式(Memento Pattern)
备忘录模式(Memento Pattern) 介绍 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到保存的状态. 示例 有一个Message实体类 ...
- 『设计模式』备忘录模式(memento)下象棋,我就想悔棋怎么办
23种设计模式+额外常用设计模式汇总 (持续更新) Memento模式的关键就是要在不破坏封装性的前提下,捕获一个对象的内部状态并在该对象之外保存这个状态.这样以后就可以利用该保存的状态实施恢复操作. ...
- 【设计模式】—— 备忘录模式Memento
前言:[模式总览]----------by xingoo 模式意图 这个模式主要是想通过一个对象来记录对象的某种状态,这样有利于在其他需要的场合进行恢复. 该模式还有跟多可以扩展的地方,比如可以记录多 ...
- 设计模式-备忘录模式(Memento)-Java
设计模式-备忘录模式(Memento)-Java 目录 文章目录 1.前言 2.示例案例-可悔棋的中国象棋 3.备忘录模式概述 3.1.备忘录模式定义 3.2.备忘录模式结构 3.3.备忘录模式结构图 ...
- 【学习笔记】设计模式-备忘录模式(Memento)
文章目录 0 设计模式 1 备忘录模式 2 实现思路 3 需要的类 4 具体实现 4.1 Memento(备忘录) 4.2 Originator(目标对象) 4.3 CareTaker(管理者) 4. ...
- 备忘录模式 Memento 快照模式 标记Token模式 行为型 设计模式(二十二)
备忘录模式 Memento 沿着脚印,走过你来时的路,回到原点. 苦海翻起爱恨 在世间难逃避命运 相亲竟不可接近 或我应该相信是缘份 一首<一生所爱>触动了多少人的心弦,一段五百年都没有结 ...
- java备忘录模式应用场景_图解Java设计模式之备忘录模式
图解Java设计模式之备忘录模式 游戏角色状态恢复问题 游戏角色有攻击力和防御力,在大战Boss前保存自身的状态(攻击力和防御力),当大战Boss后攻击力和防御力下降,从备忘录对象恢复到大战前的状态. ...
- Alamps学习设计模式之备忘录模式(笑话:劫个色OR抢个鸡蛋版)
//设计模式之备忘录模式(月光宝盒版),只要喊菠萝菠萝蜜,就能返回事件的原点.//至尊宝//爱你一万年 class LoverWords {// 模拟Memento private Strin ...
- 设计模式之备忘录模式 转载
https://juejin.im/post/59c8eb6951882564c5164c5f 设计模式之备忘录模式 备忘录模式 介绍 是一种行为模式 用于保存对象当前状态,并在之后恢复到此状态(后悔 ...
最新文章
- 《修改代码的艺术》迷你书
- hadoop2.4.1结合hbase0.96.2
- Matlab R2010在centost下的安装
- jmeter java接口_JMeter接口Java开发五步曲
- ebnf范式_使用Scala基于词法单元的解析器定制EBNF范式文法解析
- 转list_quot;quot;转 Int,{} 转 List,还有什么奇葩的 JSON 要容错?| 实战
- OpenShift 4 - Pod的亲和性/反亲和性
- 第七章部分例题最大乘积
- springboot项目解决跨域的几种方式
- 变分自编码器(VAE)详解与实现(tensorflow2.x)
- CSS 实现文字两端对齐
- USBVIEW(带已分配带宽显示功能)-电脑圈圈
- Elasticsearch自定义插件
- html5播放器 php,PHP/HTML5页面上的随机声音播放器
- Youtube上播放量前100的单曲整理
- 怎么找主播卖货?最靠谱的5种直播带货方式
- 端游开发用什么技术可以让用户更短时间内体验游戏?端游分发
- 粒子群算法(PSO)基本原理
- 加州大学圣地亚哥分校计算机科学排名,加州大学圣地亚哥分校计算机科学硕士排名第18(2020年TFE Times排名)...
- 文件锁定工具IObit Unlocker v1.2.0单文件
热门文章
- 力扣(LeetCode)刷题,简单题(第5期)
- mysqlorderby数字字符串排序_Python中的元组排序和深度比较
- 残差神经网络_什么是残差——一文让你读懂GBDT(梯度提升树)-和-Resnet-(残差网络)的原理...
- PCL的PNG文件和计算点云重心
- ADPRL - 近似动态规划和强化学习 - Note 4 - Policy Iteration Algorithms
- eclipse设置代码自动保存步骤
- ATS 5.3.0中开启最高级别的缓存调试信息
- 在ATS 5.3.0上开启stats_over_http插件
- SSL证书可以给多个域名使用吗?
- Unity协程截图,WWWForm、WWW配合上传