JAVA設(shè)計(jì)模式之備忘錄模式原理與用法詳解
本文實(shí)例講述了JAVA設(shè)計(jì)模式之備忘錄模式。分享給大家供大家參考,具體如下:
備忘錄模式:又叫做快照模式,指在不破壞封裝性的前提下,獲取到一個(gè)對(duì)象的內(nèi)部狀態(tài),并在對(duì)象之外記錄或保存這個(gè)狀態(tài)。在有需要的時(shí)候可將該對(duì)象恢復(fù)到原先保存的狀態(tài)。我們相當(dāng)于把對(duì)象原始狀備份保留,所以叫備忘錄模式。
*模式 角色對(duì)象組成:
1.發(fā)起者對(duì)象:負(fù)責(zé)創(chuàng)建一個(gè)備忘錄來記錄當(dāng)前對(duì)象的內(nèi)部狀態(tài),并可使用備忘錄恢復(fù)內(nèi)部狀態(tài)。
2.備忘錄對(duì)象:負(fù)責(zé)存儲(chǔ)發(fā)起者對(duì)象的內(nèi)部狀態(tài),并防止其他對(duì)象訪問備忘錄。
3.管理者對(duì)象:負(fù)責(zé)備忘錄權(quán)限管理,不能對(duì)備忘錄對(duì)象的內(nèi)容進(jìn)行訪問或者操作。
優(yōu)點(diǎn):
1、備忘錄模式可以把發(fā)起人內(nèi)部信息對(duì)象屏蔽起來,從而可以保持封裝的邊界。
2、簡(jiǎn)化了發(fā)起人類。當(dāng)發(fā)起人角色的狀態(tài)改變的時(shí)候,有可能這個(gè)狀態(tài)無效,這時(shí)候就可以使用暫時(shí)存儲(chǔ)起來的備忘錄將狀態(tài)復(fù)原。
缺點(diǎn):
1、如果狀態(tài)需要完整地存儲(chǔ)到備忘錄對(duì)象中,那么在資源消耗上面?zhèn)渫泴?duì)象比較昂貴。
2、當(dāng)發(fā)起者對(duì)象的狀態(tài)改變的時(shí)候,有可能這個(gè)協(xié)議無效。如果狀態(tài)改變的成功率達(dá)不到要求,可以考慮采取“假如”協(xié)議模式。
/**
* 備忘錄對(duì)象類
* @description:
* @date 2016-1-22 上午11:15:59
*/
public class MemoBean {
private int useTime;//使用時(shí)間
private String deviceName;//設(shè)備名稱
private int stateLevel;//狀態(tài)
public int getUseTime() {
return useTime;
}
public void setUseTime(int useTime) {
this.useTime = useTime;
}
public String getDeviceName() {
return deviceName;
}
public void setDeviceName(String deviceName) {
this.deviceName = deviceName;
}
public int getStateLevel() {
return stateLevel;
}
public void setStateLevel(int stateLevel) {
this.stateLevel = stateLevel;
}
}
/**
* 備忘錄管理對(duì)象
* @description:
* @date 2016-1-22 上午11:15:25
*/
public class MemoManager {
MemoBean memento;
public MemoBean getMemento() {
return memento;
}
public void setMemento(MemoBean memento) {
this.memento = memento;
}
}
/**
* 發(fā)起者對(duì)象
* @description:
* @date 2016-1-22 上午11:21:18
*/
public class MemoRole {
private int useTime;// 使用時(shí)間
private String deviceName;// 設(shè)備名稱
private int stateLevel;// 狀態(tài)
public MemoRole(String deviceName, int useTime, int stateLevel) {
super();
this.useTime = useTime;
this.deviceName = deviceName;
this.stateLevel = stateLevel;
}
public MemoRole() {
}
public int getUseTime() {
return useTime;
}
public void setUseTime(int useTime) {
this.useTime = useTime;
}
public String getDeviceName() {
return deviceName;
}
public void setDeviceName(String deviceName) {
this.deviceName = deviceName;
}
public int getStateLevel() {
return stateLevel;
}
public void setStateLevel(int stateLevel) {
this.stateLevel = stateLevel;
}
public MemoBean createMemoObject() {
MemoBean memento = new MemoBean();
memento.setDeviceName(deviceName);
memento.setStateLevel(stateLevel);
memento.setUseTime(useTime);
return memento;
}
public void setMemento(MemoBean memento) {
this.deviceName = memento.getDeviceName();
this.stateLevel = memento.getStateLevel();
this.useTime = memento.getUseTime();
}
/**
* 獲取對(duì)象當(dāng)前狀態(tài)
* @description:
* @author ldm
* @date 2016-1-22 下午12:15:09
*/
public void getCurrentState() {
System.out.println("當(dāng)前設(shè)備名稱:" + this.deviceName + "當(dāng)前使用時(shí)間:" + this.useTime + "當(dāng)前工作狀態(tài):" + this.stateLevel);
}
}
測(cè)試類
public class Test {
public static void main(String[] args) {
// 新建備忘錄發(fā)起者對(duì)象
MemoRole role = new MemoRole("發(fā)電機(jī)", 0, 1);
// 新建備忘錄管理者
MemoManager manager = new MemoManager();
// 角色初始狀態(tài)
System.out.println("機(jī)器開始發(fā)電:");
role.getCurrentState();
// 利用備忘錄模式保存當(dāng)前狀態(tài)
System.out.println("---保存當(dāng)前的機(jī)器狀態(tài)---");
manager.setMemento(role.createMemoObject());
role.setDeviceName("發(fā)電機(jī)");
role.setStateLevel(5);
role.setUseTime(1000);
System.out.println("已經(jīng)持續(xù)發(fā)電1000小時(shí)");
role.getCurrentState();
// 恢復(fù)保存的角色狀態(tài)
role.setMemento(manager.getMemento());
System.out.println("恢復(fù)后發(fā)電機(jī)當(dāng)前狀態(tài):");
role.getCurrentState();
}
}
結(jié)果:
機(jī)器開始發(fā)電: 當(dāng)前設(shè)備名稱:發(fā)電機(jī)當(dāng)前使用時(shí)間:0 當(dāng)前工作狀態(tài):1 —保存當(dāng)前的機(jī)器狀態(tài)— 已經(jīng)持續(xù)發(fā)電N小時(shí) 當(dāng)前設(shè)備名稱:發(fā)電機(jī)當(dāng)前使用時(shí)間:1000 當(dāng)前工作狀態(tài):5 恢復(fù)后發(fā)電機(jī)當(dāng)前狀態(tài): 當(dāng)前設(shè)備名稱:發(fā)電機(jī)當(dāng)前使用時(shí)間:0 當(dāng)前工作狀態(tài)1
運(yùn)行結(jié)果的最后一句表示回到了初始狀態(tài),起到了備份作用。
更多java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。
- Java設(shè)計(jì)模式初識(shí)之備忘錄模式詳解
- Java設(shè)計(jì)模式之備忘錄模式
- 深入理解Java設(shè)計(jì)模式之備忘錄模式
- Java設(shè)計(jì)模式之java備忘錄模式詳解
- 實(shí)例講解JAVA設(shè)計(jì)模式之備忘錄模式
- 詳解備忘錄模式及其在Java設(shè)計(jì)模式編程中的實(shí)現(xiàn)
- 詳解Java設(shè)計(jì)模式之備忘錄模式的使用
- Java設(shè)計(jì)模式之備忘錄模式(Memento模式)介紹
- Java設(shè)計(jì)模式之備忘錄模式實(shí)現(xiàn)對(duì)象狀態(tài)的保存和恢復(fù)
相關(guān)文章
java利用冒泡排序?qū)?shù)組進(jìn)行排序
這篇文章主要介紹了java利用冒泡排序?qū)?shù)組進(jìn)行排序的方法,實(shí)例分析了冒泡排序的概念與java實(shí)現(xiàn)方法,以及java操作數(shù)組的相關(guān)技巧,需要的朋友可以參考下2015-05-05
詳解Java編程中protected修飾符與static修飾符的作用
這篇文章主要介紹了Java編程中protected關(guān)鍵字與static關(guān)鍵字的作用,是Java入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-01-01
Java中的ArrayList和contains函數(shù)和擴(kuò)容機(jī)制(源碼詳解)
這篇文章主要介紹了Java中的ArrayList和contains函數(shù)和擴(kuò)容機(jī)制,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-10-10
Java使用JSQLParser解析和操作SQL的技術(shù)指南
在開發(fā)過程中,解析和操作?SQL?是一個(gè)常見的需求,JSQLParser?是一個(gè)強(qiáng)大的開源?Java?庫,用于解析?SQL?并提供語法樹操作功能,本文將詳細(xì)介紹如何使用?JSQLParser,并提供常見使用場(chǎng)景的代碼示例,需要的朋友可以參考下2025-04-04
Struts2學(xué)習(xí)筆記(6)-簡(jiǎn)單的數(shù)據(jù)校驗(yàn)
這篇文章主要介紹Struts2中的數(shù)據(jù)校驗(yàn),通過一個(gè)簡(jiǎn)單的例子來說明,希望能給大家做一個(gè)參考。2016-06-06
@WebFilter在SpringBoot無效的原因分析和解決方案
使用Ruoyi的demo部署成功后,發(fā)現(xiàn)js、css等靜態(tài)文件都進(jìn)入了過濾器,但是發(fā)現(xiàn)靜態(tài)文件沒有使用瀏覽器緩存,新建BrowserCacheFilter.java并增加@WebFilter處理,應(yīng)用自動(dòng)重啟后發(fā)現(xiàn)@WebFilter無效,所以本文給大家介紹了@WebFilter在SpringBoot無效的原因分析和解決方案2024-03-03
使用WebSocket實(shí)現(xiàn)即時(shí)通訊(一個(gè)群聊的聊天室)
這篇文章主要為大家詳細(xì)介紹了使用WebSocket實(shí)現(xiàn)即使通訊,實(shí)現(xiàn)一個(gè)群聊的聊天室,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03

