个人博客:打开链接
一、备忘录模式的定义
- Memento Pattern
- “传说中的后悔药”
- Without violating encapsulation,capture and externalize an object’s
internal state so that the object can be restored to this state
later.(在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,这样以后就可将该对象恢复到原来保存的状态) - 通俗来讲,备忘录模式就是一个对象的备份模式,提供了一种程序数据的备份方法
二、通用类图
- Originator发起人角色:记录当前时刻的内部状态,负责定义哪些属于备份范围内的状态,负责创建和恢复备忘录数据。
- Memento备忘录角色:负责存储Originator发起人对象的内部状态,在需要时提供发起人需要的内部状态。
- Caretaker备忘录管理员角色:对备忘录进行管理、保存和提供备忘录。
三、通用代码
发起人角色:
public class Originator {
// 内部状态
private String state = "";
// 获取内部状态
public String getState() {
return state;
}
// 设置内部状态
public void setState(String state) {
this.state = state;
}
// 创建一个备忘录
public Memento createMemento() {
return new Memento(this.state);
}
// 恢复一个备忘录
public void restoreMemento(Memento memento) {
this.setState(memento.getState());
}
}
备忘录角色:
public class Memento {
// 发起人的内部状态
private String state = "";
// 构造函数传递参数
public Memento(String state) {
super();
this.state = state;
}
public String getState() {
return state;
}
public void setState(String state) {
this.state = state;
}
}
备忘录管理者:
public class Caretaker {
// 备忘录对象
private Memento momento;
public Memento getMomento() {
return momento;
}
public void setMomento(Memento momento) {
this.momento = momento;
}
}
场景类:
public class Client {
public static void main(String[] args) {
// 定义发起人
Originator originator = new Originator();
// 定义出备忘录管理员
Caretaker caretaker = new Caretaker();
// 创建一个备忘录
caretaker.setMomento(originator.createMemento());
// 恢复一个备忘录
originator.restoreMemento(caretaker.getMomento());
}
}
四、备忘录的使用场景
- 需要保存和恢复数据的相关状态场景
- 提供一个可回滚的操作;比如Word中的【Ctrl+z】、IE上的返回键、文件管理器上的backspace键等
- 需要监控的副本场景中–监控一个对象的属性,但是监控又不应该作为系统的主业务来调用,它只是边缘应用,即使出现监控不准、错误报警也影响不大,因此一般的做法是备份一个主线程中的对象,然后由分析程序来分析
- 数据库连接的事务管理就是用的备忘录模式,想想看,如果要实现一个JDBC驱动,你用什么来实现事务,还不是用备忘录吗!
五、备忘录模式的注意事项
- 备忘录的生命周期:建立就要使用,不使用就要立即删除其引用,等待垃圾回收器对它的回收处理
- 备忘录的性能:不要在频繁建立备份的场景中使用备忘录模式
- 控制不了备忘录建立的对象数量
- 建立对象是需要消耗资源的,系统的性能需要考虑