设计模式-备忘录模式
生活随笔
收集整理的這篇文章主要介紹了
设计模式-备忘录模式
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
備忘錄模式(Memento):
? ??在不破壞封裝性的前提下,捕獲一個對象的內部狀態,并在該對象之外保存這個狀態。這樣以后就可以將該對象回復到原先保存的狀態。
Originator(發起人):負責創建一個備忘錄Memento,用以記錄當前時刻它的內部狀態,并且使用備忘錄恢復內部狀態。Originator可根據需要決定Memento存儲Originator的哪些內部狀態。
Memento(備忘錄):負責存儲Originator對象的內部狀態,并可防止Originator以外的其他對象訪問備忘Memento。備忘錄有兩個接口,Caretaker只能看到備忘錄的窄接口,它只能講備忘錄傳遞給其他對象。Originator能夠看到一個寬接口,允許它訪問返回到先前狀態所需要的所有數據。Caretaker(管理者):負責保存好備忘錄Memento,不能對備忘錄的內容進行操作或檢查。
備忘錄模式代碼:
#pragma once #include <string> #include <iostream> using namespace std;//備忘錄(Memento) class Cmemento { public:string m_strState; public:Cmemento(string strState){m_strState = strState;} };//發起人(Originator)類 class COriginator { public:string m_strState; public:Cmemento * CreateMemento(){return new Cmemento(m_strState);}void SetMemento(Cmemento * pMemento){m_strState = pMemento->m_strState;}void Show(){cout<<"State="<<m_strState<<endl;} };//管理者(Creataker)類 class CCaretaker { public:Cmemento *m_pMemento; };客戶端使用代碼:
#include "stdafx.h" #include "MementoMode.h" #include <windows.h> using namespace std;int main() {COriginator *pO = new COriginator();pO->m_strState = "On";pO->Show();CCaretaker *pC = new CCaretaker();pC->m_pMemento = pO->CreateMemento();pO->m_strState = "Off";pO->Show();pO->SetMemento(pC->m_pMemento);pO->Show();delete pO;delete pC->m_pMemento;delete pC;return 0; }運行結果:
OK上面就是備忘錄模式,其實可以想成是某個軟件的臨時快照等等,但是上面的很多地方用了public,本身應該考慮set,get的,為了方便就直接public了,但是應該要清楚這么寫對封裝一點沒有好處,而且寫的時候也會很難受。今天又太晚了,我就不改了就上面那樣吧,大家理解備忘錄模式的思想就好。
總結
以上是生活随笔為你收集整理的设计模式-备忘录模式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 设计模式-UML图简单介绍
- 下一篇: Intel汇编语言程序设计学习-第一章