设计模式——备忘录模式(C++实现)

  1 #include <iostream>
  2 #include <string>
  3 #include <vector>
  4
  5 using namespace std;
  6
  7 class STMemento
  8 {
  9 private:
 10         int iVitality;
 11 public:
 12         STMemento(){}
 13         STMemento(int iVitality)
 14         {
 15                 this->iVitality = iVitality;
 16         }
 17
 18         int GetVitality() const
 19         {
 20                 return this->iVitality;
 21         }
 22 };
 23
 24 class STOriginator
 25 {
 26 private:
 27         int iVitality;
 28         string name;
 29 public:
 30         STOriginator(string strName, int iVit): iVitality(iVit), name(strName)
 31         {
 32
 33         }
 34
 35         STMemento* SaveState()
 36         {
 37                 return new STMemento(iVitality);
 38         }
 39
 40         void RecoverState(const STMemento* stMemento)
 41         {
 42                 this->iVitality = stMemento->GetVitality();
 43         }
 44
 45         void SetVitality(int iVit)
 46         {
 47                 this->iVitality = iVit;
 48         }
 49
 50         void Show()
 51         {
 52                 cout<< "Name: "<< name<< endl;
 53                 cout<< "Live: "<< iVitality<< endl;
 54         }
 55 };
 56
 57 class STCareTaker
 58 {
 59 private:
 60         vector<STMemento*> vecStMemento;
 61
 62 public:
 63         void AddMemento(STMemento* stMemento)
 64         {
 65                 vecStMemento.push_back(stMemento);
 66         }
 67
 68         STMemento* GetMemento(int Iindex)
 69         {
 70                 if (Iindex >= vecStMemento.size())
 71                         return NULL;
 72                 else
 73                         return vecStMemento[Iindex];
 74         }
 75 };
 76
 77 int main(int argc, char* argv[])
 78 {
 79         STOriginator* pstOriginator = new STOriginator("xxx", 100);
 80         cout<< "原始状态: "<< endl;
 81         pstOriginator->Show();
 82
 83         STCareTaker* pstCareTaker = new STCareTaker();
 84         pstCareTaker->AddMemento(pstOriginator->SaveState());
 85
 86         pstOriginator->SetVitality(50);
 87         cout<< "战斗后状态: "<< endl;
 88         pstOriginator->Show();
 89
 90         pstOriginator->RecoverState(pstCareTaker->GetMemento(0));
 91         cout<< "归档后状态: "<< endl;
 92         pstOriginator->Show();
 93
 94         return 0;
 95 }
 96 /////////////////////////////
 97 [[email protected] ~/learn_code/design_pattern/15_memento]$ ./memento
 98 原始状态:
 99 Name: xxx
100 Live: 100
101
102 战斗后状态:
103 Name: xxx
104 Live: 50
105
106 归档后状态:
107 Name: xxx
108 Live: 100
时间: 2024-10-15 12:54:59

设计模式——备忘录模式(C++实现)的相关文章

【C#设计模式-备忘录模式】

一.备忘录模式的定义: 在不破坏封闭的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态. 二.备忘录模式的结构和角色: 1.Originator(发起人):负责创建一个备忘录Memento,用以记录当前时刻自身的内部状态,并可使用备忘录恢复内部状态.Originator可以根据需要决定Memento存储自己的哪些内部状态. 2.Memento(备忘录):负责存储Originator对象的内部状态,并可以防止Originator以外的其他对象访问

我的设计模式:备忘录模式

我的设计模式-备忘录模式 恢复到最初的状态-->对原始状态的保留和恢复 联想到的业务:cms稿件放入到回收站,永久记录状态得用到数据库啊,怎么办?备忘录模式的内存缓存不适用? 类的单一职责 boy职责:状态   改变状态  设置状态  获取状态 备忘录职责:记录当前的状态   恢复状态 迪 米特原则:最少知道原则,不和陌生人说话 问题:备忘录只是记录了一个节点,多个备忘录记录了多个节点,可以恢复到任意节点?备忘录因该支持多个节点? 思考问题:增加备忘录管理者manager角色,有啥好处呢?没体验

[转] Android中的设计模式-备忘录模式

转自Android中的设计模式-备忘录模式 定义 备忘录设计模式的定义就是把对象的状态记录和管理委托给外界处理,用以维持自己的封闭性. 比较官方的定义 备忘录模式(Memento Pattern)又叫做快照模式(Snapshot Pattern)或Token模式,是GoF的23种设计模式之一,属于行为模式. 定义:在不破坏封闭的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态. 角色 笔记本:很多的内部状态需要被建立一个备忘录来管理,创建和取出

设计模式--备忘录模式(Memento)

什么是备忘录模式? 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,这样就可以将以后的对象状态恢复到先前保存的状态. 我们在编程的时候,经常需要保存对象的中间状态,当需要的时候,可以恢复到这个状态.比如,我们使用Eclipse进行编程时,假如编写失误(例如不小心误删除了几行代码),我们希望返回删除前的状态,便可以使用Ctrl+Z来进行返回.这时我们便可以使用备忘录模式来实现. 代码示例: 代码演示了一个单状态单备份的例子,逻辑非常简单:Originator类中的sta

[工作中的设计模式]备忘录模式memento

一.模式解析 备忘录对象是一个用来存储另外一个对象内部状态的快照的对象.备忘录模式的用意是在不破坏封装的条件下,将一个对象的状态捕捉(Capture)住,并外部化,存储起来,从而可以在将来合适的时候把这个对象还原到存储起来的状态.备忘录模式常常与命令模式和迭代子模式一同使用. 备忘录模式可以根据客户指令,将相应的对象特有属性进行快照,如果客户要恢复对象,则根据快照提供的特有属性进行还原. 二.模式代码 package memento.patten; /** *备忘录类,同时指定要保存的对象属性

PHP设计模式——备忘录模式

声明:本系列博客參考资料<大话设计模式>,作者程杰. 备忘录模式又叫做快照模式或Token模式,在不破坏封闭的前提下.捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态. UML类图: 角色: 1.发起人(GameRole):负责创建一个备忘录,用以记录当前时刻自身的内部状态,并可使用备忘录恢复内部状态.发起人能够依据须要决定备忘录存储自己的哪些内部状态. 2.备忘录(RoleStateSaveBox):负责存储发起人对象的内部状态,并能够防止发起人以

设计模式-备忘录模式实现悔棋操作

利用设计模式中的备忘录模式实现多步悔棋的操作 1 import java.util.*; 2 class Chessman { 3 private String label; 4 private int x; 5 private int y; 6 public static int index=-1; 7 public Chessman(String label,int x,int y) { 8 this.label = label; 9 this.x = x; 10 this.y = y; 1

[设计模式] 备忘录模式Memento Pattern

在GOF的<设计模式:可复用面向对象软件的基础>一书中对备忘录模式是这样说的:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可将该对象恢复到原先保存的状态. 类图和实例: 简单的模式实例: #include <iostream> #include <string> using namespace std; class Memento { private:     string state; public:     Memento(

大话设计模式—备忘录模式

备忘录模式(Memento Pattern)保存一个对象的某个状态,以便在适当的时候恢复对象.备忘录模式属于行为型模式.所谓备忘录模式就是在不破坏封装的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,这样可以在以后将对象恢复到原先保存的状态.很多时候我们总是需要记录一个对象的内部状态,这样做的目的就是为了允许用户取消不确定或者错误的操作,能够恢复到他原先的状态,使得他有"后悔药"可吃. 大话设计模式中程杰老师给出的定义是,备忘录模式:在不破坏封装性的前提下,捕获一个对象的内

深入浅出设计模式——备忘录模式(Memento Pattern)

模式动机 为了使软件的使用更加人性化,对于误操作,我们需要提供一种类似“后悔药”的机制,让软件系统可以回到误操作前的状态,因此需要保存用户每一次操作时系统的状态,一旦出现误操作,可以把存储的历史状态取出即可回到之前的状态.现在大多数软件都有撤销(Undo)的功能,快捷键一般都是Ctrl+Z,目的就是为了解决这个后悔的问题. 在应用软件的开发过程中,很多时候我们都需要记录一个对象的内部状态.在具体实现过程中,为了允许用户取消不确定的操作或从错误中恢复过来,需要实现备份点和撤销机制,而要实现这些机制