备忘录模式:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,这样以后就可以将该对象恢复到原来保存的状态。
应用实例: 1、后悔药。 2、打游戏时的存档。 3、Windows 里的 ctri + z。 4、IE 中的后退。 4、数据库的事务管理。
实例UML图:

代码实现:
/**
* @author Shuyu.Wang
* @package:com.shuyu.memento
* @description:备忘录,负责存储Originator对象的内部状态,并可防止Originator以外的其他对象访问备忘录
* Memento,备忘录有两个接口,Caretaker只能看到备忘录的窄接口,他只能将备忘录传递给其他对象。
* @date 2018-11-27 21:36
**/
@Data
public class Memento {
private String state;
public Memento(String state){
this.state=state;
}
}
/**
* @author Shuyu.Wang
* @package:com.shuyu.memento
* @description:发起人,负责创建一个备忘录,用以记录当前时刻他的内部状态,并可使用备忘录恢复内部状态。
* 可根据需要决定Memento存储Originator的哪些内部状态
* @date 2018-11-27 21:33
**/
@Slf4j
@Data
public class Originator {
private String state;
public Memento createMemento(){
return new Memento(state);
}
public void setMemento(Memento memento){
state=memento.getState();
}
public void show(){
log.info("State="+state);
}
}
/**
* @author Shuyu.Wang
* @package:com.shuyu.memento
* @description:管理者,负责变成号备忘录Memento,不能对备忘录的内容进行操作或检查
* @date 2018-11-28 12:43
**/
@Data
public class Caretaker {
private Memento memento;
}
测试代码:
@RunWith(SpringRunner.class)
@SpringBootTest
public class MementoApplicationTests {
@Test
public void contextLoads() {
Originator originator=new Originator();
originator.setState("ON");
originator.show();
Caretaker c=new Caretaker();
c.setMemento(originator.createMemento());
originator.setState("off");
originator.show();
originator.setMemento(c.getMemento());
originator.show();
}
}
运行结果:
2018-11-28 12:54:45.935 INFO 6184 --- [ main] com.shuyu.memento.Originator : State=ON
2018-11-28 12:54:45.936 INFO 6184 --- [ main] com.shuyu.memento.Originator : State=off
2018-11-28 12:54:45.936 INFO 6184 --- [ main] com.shuyu.memento.Originator : State=ON
代码github地址:
https://github.com/iot-wangshuyu/designpatterns/tree/master/memento

414

被折叠的 条评论
为什么被折叠?



