备忘录模式
时间:2022-04-26
本文章向大家介绍备忘录模式,主要内容包括概念、结构与组成、代码实例、备忘录的优点、缺点及适用场合、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
概念
备忘录模式:又叫做快照模式,属于行为模式的一种,指在不破坏封装性的前提下,获取到一个对象的内部状态,并在对象之外记录或保存这个状态。在有需要的时候可将该对象恢复到原先保存的状态。我们相当于把对象原始状备份保留,所以叫备忘录模式。
结构与组成
首先看一下备忘录模式的UML图:
备忘录模式主要包含:发起者对象(Originator)、备忘录(Memento)和管理者角色(Caretaker)三部分组成。 发起者对象:负责创建一个备忘录来记录当前对象的内部状态,并可使用备忘录恢复内部状态。 .备忘录对象:负责存储发起者对象的内部状态,并防止其他对象访问备忘录。 管理者对象:负责备忘录权限管理,不能对备忘录对象的内容进行访问或者操作。 在备忘录模式中Caretaker负责把Originator进行备份,在需要的时候Originator可以使用Caretaker中保存的Originator进行恢复,Originator的各种状态就可以恢复到修改之前的状态。
代码实例
发起者对象
public class MemoRole {
private int useTime;// 使用时间
private String deviceName;// 设备名称
private int stateLevel;// 状态
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();
}
public void getCurrentState() {
System.out.println("当前设备名称:" + this.deviceName + "当前使用时间:" + this.useTime + "当前工作状态:" + this.stateLevel);
}
}
备忘录对象类
public class MemoBean {
private int useTime;//使用时间
private String deviceName;//设备名称
private int stateLevel;//状态
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 class MemoManager {
MemoBean memento;
public MemoBean getMemento() {
return memento;
}
public void setMemento(MemoBean memento) {
this.memento = memento;
}
}
客户端测试类:
public class Test {
public static void main(String[] args) {
// 新建备忘录发起者对象
MemoRole role = new MemoRole("发电机", 0, 1);
// 新建备忘录管理者
MemoManager manager = new MemoManager();
// 角色初始状态
System.out.println("机器开始发电:");
role.getCurrentState();
// 利用备忘录模式保存当前状态
System.out.println("---保存当前的机器状态---");
manager.setMemento(role.createMemoObject());
role.setDeviceName("发电机");
role.setStateLevel(5);
role.setUseTime(1000);
System.out.println("已经持续发电1000小时");
role.getCurrentState();
// 恢复保存的角色状态
role.setMemento(manager.getMemento());
System.out.println("恢复后发电机当前状态:");
role.getCurrentState();
}
}
备忘录的优点、缺点及适用场合
优点: 1、备忘录模式可以把发起人内部信息对象屏蔽起来,从而可以保持封装的边界。 2、简化了发起人类。当发起人角色的状态改变的时候,有可能这个状态无效,这时候就可以使用暂时存储起来的备忘录将状态复原。 缺点: 1、如果状态需要完整地存储到备忘录对象中,那么在资源消耗上面备忘录对象比较昂贵。 2、当发起者对象的状态改变的时候,有可能这个协议无效。如果状态改变的成功率达不到要求,可以考虑采取“假如”协议模式。 适用场合:
- 必须保存一个对象在某一时刻的状态,以便恢复到先前的状态。
- 如果用一个接口来网其他对象直接得到被保存对象的内部状态,将会暴露对象的实现细节并破坏了对象的封装性。
- 你不知道的javaScript笔记(7)
- Contact Manager Web API 示例[4] 异常处理(Exception Handling)
- 你不知道的javaScript笔记(6)
- 创建支持多种屏幕尺寸的Android应用
- 封装多线程处理大量数据操作
- 你不知道的javaScript笔记(5)
- 无特性的 MEF 配置方法
- HTTP协议状态码详解(HTTP Status Code)
- android 中resources管理
- 你不知道的javaScript笔记(4)
- Android网格视图(GridView)
- http响应Last-Modified和ETag以及asp.net web api实现
- 列表视图(ListView和ListActivity)
- 你不知道的javaScript笔记(3)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 一文帮你理解整个 SRE 运维体系!
- 拆解式解读如何用飞桨复现胶囊神经网络(Capsule Network)
- 我用飞桨Parakeet合成小姐姐声音帮我“读”论文
- 【5分钟玩转Lighthouse】搭建WordPress博客
- vue接入腾讯地图(一)【点击事件】
- Redis文件事件&时间事件处理机制
- Redis持久化策略
- Redis二进制安全的原理
- 面试必备 Vue 知识点
- 数据传输 | mysqldiff/mysqldbcompare 实现 DTLE 自动化测试
- CPU有个禁区,内核权限也无法进入!
- 分布式 | DBLE 3.20.07.0 来啦!
- C语言三剑客之《C陷阱与缺陷》一书精华提炼
- Linux进程间通信(上)之管道、消息队列实践
- FPGA上电时序