备忘录模式之C++实现
说明:本文仅供学习交流。转载请标明出处,欢迎转载。
备忘录模式是一种比較简单的设计模式。该模式非常好地体现了一种面向对象的封装思想。
该模式的思想是用一个专门的备份类将当前的状态信息保存起来。在整个过程中用户不能直接接触该备份类,为了达到这个目的。须要创建一个管理类,用户对先前的信息进行备份和还原。这样,假设用户想备份当前信息或者还原至前一个状态,我们能够通过该管理类的对象来调用备份函数和还原函数。
当然,我们所示全部状态都是由一个执行类提供。
为了说明上面的思想,我们将上面所提到的执行类用Originator表示。备忘类用Memento表示,管理类用Caretaker表示。同一时候各个类都有分工:执行类用于执行当前的状态。管理类用于备份和恢复状态,备忘类则是一种底层的数据结构(用于保存状态信息),是管理类和执行类沟通的桥梁。
备忘录模式(Memento)的定义:在不破坏封装性的前提下。捕获一个对象的内部状态,并在该对象之外保存这个状态,这样以后就能够将该对象恢复到原先保存的状态。
备忘录模式的结构:
本图来自《大话设计模式》
C++实现代码:
#include<iostream>
#include<string>
using namespace std;
class Memento//用于保存之前信息的类,这个类不与client打交道
{
private:
string state;//用于保存之前状态
public:
Memento(){}
Memento(string s):state(s){};
string GetState(){return state;}
}; class Originator//行动发起者类,总是相应如今进行时,client用这个类进行正常的操作
{
private:
string state;//相应的状态为当前的状态
public:
void SetState(string state)//设置状态信息
{
this->state=state;
}
Memento CreateMemento()//返回当前的信息
{
return Memento(state);
}
void SetMento(Memento mem)
{
this->state=mem.GetState();
}
void Show()
{
cout<<"当前状态为:"<<state<<endl;
}
};
class CareTaker//管理者,用户端用这个类进行数据的备份
{
private:
Memento memento;//全部的备份信息都保存在对象mem中
public:
Memento GetMemento()//返回备份信息的对象
{
return memento;
}
void SetMemento(Memento men)//备份信息
{
this->memento=men;
cout<<"当前状态信息已备份!"<<endl;
}
}; int main()//client程序
{
Originator org;
/*******显示当前的状态信息*******/
cout<<"显示当前状态..."<<endl;
org.SetState("打开状态!");//将当前的状态设置为打开状态
org.Show(); /*******备份当前的状态信息*******/
cout<<endl<<"备份当前的状态信息..."<<endl;
CareTaker ct;
ct.SetMemento(org.CreateMemento());//备份当前状态信息 /*******设置新的状态*******/
cout<<endl<<"又一次设置当前的状态...."<<endl;
org.SetState("关闭状态!");
org.Show(); /********恢复先前的状态*******/
cout<<endl<<"恢复先前的状态....."<<endl;
org.SetMento(ct.GetMemento());
org.Show();
return 0;
}
測试结果例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvSlhIXzEyMw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
參考资料:
[1]《大话设计模式》
[2]《设计模式之禅》
[3]《HeadFirst设计模式》
备忘录模式之C++实现的更多相关文章
- MementoPattern(备忘录模式)
/** * 备忘录模式 * @author TMAC-J * 用于存储bean的状态 */ public class MementoPattern { public class Memento{ pr ...
- C#设计模式-备忘录模式
访问者模式的实现是把作用于某种数据结构上的操作封装到访问者中,使得操作和数据结构隔离.而本文要介绍的备忘者模式与命令模式有点相似,不同的是,命令模式保存的是发起人的具体命令(命令对应的是行为),而备忘 ...
- C#设计模式系列:备忘录模式(Memento)
1.备忘录模式简介 1.1>.定义 备忘录模式在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可以将该对象恢复到原先保存的状态. 1.2>.使用频率 ...
- php实现设计模式之 备忘录模式
<?php /*备忘录模式:在不破坏封装的前提下,获取对象的内部状态,并且在对象外保存该状态.这样就可以将该对象恢复到保存之前的状态(行为模式) * * 发起人:记录当前时刻的内部状态,负责定义 ...
- java设计模式之备忘录模式
备忘录模式 备忘录模式是一种软件设计模式:在不破坏封闭的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态.一听到备忘录这个字的时候想起了小小时打的游 ...
- 备忘录模式(Memento Pattern)
在不破坏封闭的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态. 备忘录模式主要思想是——利用备忘录对象来对保存发起人的内部状态,当发起人需要恢复原 ...
- C++设计模式-Memento备忘录模式
Memento模式作用:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,这样以后就可将该对象恢复到原先保存的状态. UML图: Originator:负责创建一个备忘录Me ...
- C++设计模式-备忘录模式(1)
备忘录模式:备忘录对象时一个用来存储另外一个对象内部状态的快照对象. 备忘录模式的用意是在不破坏封装的条件下,将一个对象的状态捉住并外部化,存储起来从而可以在将来合适的时候把这个对象还原到存储起来的状 ...
- JAVA 设计模式 备忘录模式
用途 备忘录模式 (Memento) 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态. 这样以后就可将该对象恢复到原先保存的状态. 备忘录模式是一种行为型模式. 结构
- 【GOF23设计模式】备忘录模式
来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_备忘录模式.多点备忘.事务操作.回滚数据底层架构 package com.test.memento; /** * 源发器类 ...
随机推荐
- 运用反射时报错java.lang.NoSuchMethodException,以解决,记录一下
问题:想调用service类中的私有方法时, Method target=clz.getMethod("say", String.class);用Class的getMethod报错 ...
- dwarfdump --arch=arm64 --lookup
解析友盟错误信息重要指令: dwarfdump --arch=arm64 --lookup 0x1001edbc4 /Users/zhoujunbo/Library/Developer/Xcode/A ...
- JavaScipt30(第十八个案例)(主要知识点:Array.prototype.map)
承接上文,这是第十八个案例,中间的十到十八我直接看了答案,因为有些例子从他打开的页面看不出他要做什么. 附上项目链接: https://github.com/wesbos/JavaScript30 这 ...
- 2019西安多校联训 Day2
试题链接:http://www.accoders.com/contest.php?cid=1894 考试密码请私信; T1 残忍WA 0,明明就是一道非常菜的字符串QAQ 思路:一共找四种东西,A ...
- jsp中的basePath,获取应用的路径
1 2 3 4 5 String path = request.getContextPath(); String basePath = request.getScheme()+": ...
- 配置JSTL
1.去到官网下载好 4个包 http://tomcat.apache.org/download-taglibs.cgi 2.然后拷贝到 lib目录下 3.导入进去 后面的 C 代替了导入包的名字 4 ...
- 腾讯云:iptables基础
iptables 基础 iptables 基本命令 任务时间:5min ~ 10min iptables 可以简单理解为 Linux 系统内核级防火墙 netfilter 的用户态客户端. Linux ...
- 洛谷 1984 [SDOI2008]烧水问题
[题解] 烧开每一杯水之后都用它去把其他没烧开的水焐热,这样显然是最优的.然后推推式子或者列表找规律就好了. #include<cstdio> #include<algorithm& ...
- BNUOJ 33898 Cannon
Cannon Time Limit: 1000ms Memory Limit: 65535KB This problem will be judged on HDU. Original ID: 449 ...
- [bzoj1492][NOI2007]Cash[CDQ分治;dp;斜率优化]
首先,设f[x]表示x天能获得的A券最大值,有动规方程: $f[i]=max\{f[j]*A[i]+f[j]*B[i]/R[j]\}*R[i]/(R[i]*A[i]+B[i])$, 设 $j<k ...