JAVA設(shè)計模式之備忘錄模式原理與用法詳解
本文實例講述了JAVA設(shè)計模式之備忘錄模式。分享給大家供大家參考,具體如下:
備忘錄模式:又叫做快照模式,指在不破壞封裝性的前提下,獲取到一個對象的內(nèi)部狀態(tài),并在對象之外記錄或保存這個狀態(tài)。在有需要的時候可將該對象恢復(fù)到原先保存的狀態(tài)。我們相當(dāng)于把對象原始狀備份保留,所以叫備忘錄模式。
*模式 角色對象組成:
1.發(fā)起者對象:負(fù)責(zé)創(chuàng)建一個備忘錄來記錄當(dāng)前對象的內(nèi)部狀態(tài),并可使用備忘錄恢復(fù)內(nèi)部狀態(tài)。
2.備忘錄對象:負(fù)責(zé)存儲發(fā)起者對象的內(nèi)部狀態(tài),并防止其他對象訪問備忘錄。
3.管理者對象:負(fù)責(zé)備忘錄權(quán)限管理,不能對備忘錄對象的內(nèi)容進(jìn)行訪問或者操作。
優(yōu)點:
1、備忘錄模式可以把發(fā)起人內(nèi)部信息對象屏蔽起來,從而可以保持封裝的邊界。
2、簡化了發(fā)起人類。當(dāng)發(fā)起人角色的狀態(tài)改變的時候,有可能這個狀態(tài)無效,這時候就可以使用暫時存儲起來的備忘錄將狀態(tài)復(fù)原。
缺點:
1、如果狀態(tài)需要完整地存儲到備忘錄對象中,那么在資源消耗上面?zhèn)渫泴ο蟊容^昂貴。
2、當(dāng)發(fā)起者對象的狀態(tài)改變的時候,有可能這個協(xié)議無效。如果狀態(tài)改變的成功率達(dá)不到要求,可以考慮采取“假如”協(xié)議模式。
/** * 備忘錄對象類 * @description: * @date 2016-1-22 上午11:15:59 */ public class MemoBean { private int useTime;//使用時間 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; } }
/** * 備忘錄管理對象 * @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ā)起者對象 * @description: * @date 2016-1-22 上午11:21:18 */ public class MemoRole { private int useTime;// 使用時間 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(); } /** * 獲取對象當(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)前使用時間:" + this.useTime + "當(dāng)前工作狀態(tài):" + this.stateLevel); } }
測試類
public class Test { public static void main(String[] args) { // 新建備忘錄發(fā)起者對象 MemoRole role = new MemoRole("發(fā)電機", 0, 1); // 新建備忘錄管理者 MemoManager manager = new MemoManager(); // 角色初始狀態(tài) System.out.println("機器開始發(fā)電:"); role.getCurrentState(); // 利用備忘錄模式保存當(dāng)前狀態(tài) System.out.println("---保存當(dāng)前的機器狀態(tài)---"); manager.setMemento(role.createMemoObject()); role.setDeviceName("發(fā)電機"); role.setStateLevel(5); role.setUseTime(1000); System.out.println("已經(jīng)持續(xù)發(fā)電1000小時"); role.getCurrentState(); // 恢復(fù)保存的角色狀態(tài) role.setMemento(manager.getMemento()); System.out.println("恢復(fù)后發(fā)電機當(dāng)前狀態(tài):"); role.getCurrentState(); } }
結(jié)果:
機器開始發(fā)電: 當(dāng)前設(shè)備名稱:發(fā)電機當(dāng)前使用時間:0 當(dāng)前工作狀態(tài):1 —保存當(dāng)前的機器狀態(tài)— 已經(jīng)持續(xù)發(fā)電N小時 當(dāng)前設(shè)備名稱:發(fā)電機當(dāng)前使用時間:1000 當(dāng)前工作狀態(tài):5 恢復(fù)后發(fā)電機當(dāng)前狀態(tài): 當(dāng)前設(shè)備名稱:發(fā)電機當(dāng)前使用時間:0 當(dāng)前工作狀態(tài)1
運行結(jié)果的最后一句表示回到了初始狀態(tài),起到了備份作用。
更多java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計有所幫助。
相關(guān)文章
mybatis插入數(shù)據(jù)后返回自增主鍵ID的兩種實現(xiàn)方式
這篇文章主要介紹了mybatis插入數(shù)據(jù)后返回自增主鍵ID的兩種實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05SpringBoot?動態(tài)加載?Jar?包實現(xiàn)靈活的動態(tài)配置完美方案
SpringBoot作為一個開發(fā)快速、部署方便的微服務(wù)框架,具有自動配置、約定優(yōu)于配置的特點,能夠極大地提高開發(fā)效率,它提供了豐富的擴(kuò)展點,非常適合實現(xiàn)動態(tài)加載Jar包的功能,本文將深入探討如何在SpringBoot應(yīng)用中實現(xiàn)動態(tài)加載Jar包的方案,感興趣的朋友一起看看吧2024-04-04Spring三級緩存思想解決循環(huán)依賴總結(jié)分析
這篇文章主要為大家介紹了Spring三級緩存思想解決循環(huán)依賴總結(jié)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08在Spring Boot應(yīng)用程序中使用Apache Kafka的方法步驟詳解
這篇文章主要介紹了在Spring Boot應(yīng)用程序中使用Apache Kafka的方法步驟詳解,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-11-11在windows環(huán)境下安裝jdk8、jdk9、jdk11、jdk12并自由切換
這篇文章主要介紹了在windows環(huán)境下安裝jdk8、jdk9、jdk11、jdk12并自由切換,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05解決maven build 無反應(yīng),直接terminated的問題
下面小編就為大家?guī)硪黄鉀Qmaven build 無反應(yīng),直接terminated的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06Java中比較器Comparator和Comparable的區(qū)別
這篇文章主要介紹了Java中比較器Comparator和Comparable的區(qū)別,我們在使用?Collections.sort()對鏈表進(jìn)行排序時,常常需要根據(jù)不同情況自定義排序規(guī)則,今天我們來看看比較器之間的區(qū)別,需要的朋友可以參考下2023-08-08