clone模式就是配合原型模式,由一个类控制,备忘录的生产和恢复,由于是一个类包含了所有的功能,所以也不需要中转类备忘录管理员角色了
//发起人自主备份和恢复
public class Originator implements Cloneable {
private Originator backup;
private String state = "";
public String getState(){
return state;
}
public void setState(String state){
this.state = state;
}
//创建一个备忘录
public void createMenmto(){
this.backup = this.clone();
}
//恢复一个备忘录
public void restoreMenento(){
this.setState(this.backup.getState());
}
@Override
protected Originator clone(){
try {
return (Originator)super.clone();
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
return null;
}
}
//场景类
public class Main {
public static void main(String[] args) {
//定义一个发起人
Originator originator = new Originator();
//建立初始状态
originator.setState("这是初始状态");
System.out.println("当前状态:"+originator.getState());
//建立备份
originator.createMenmto();
//修改状态
originator.setState("修改状态了");
System.out.println("当前状态:"+originator.getState());
//恢复状态
originator.restoreMenento();
System.out.println("当前状态:"+originator.getState());
}
}
这样的写法程序会精简许多,而且高层模块的依赖也减少了,但是我们得考虑一下原型模式的深拷贝和浅拷贝的问题,在复杂的场景下,它会造成逻辑异常混乱,出现错误也难以跟踪,所以Clone方法的备忘录模式适用于较简单的场景
注意
使用Clone方法的备忘录模式,可以使用在比较简单的场景或者比较单一的场景设计中,尽量不要与其他的对象产生严重的耦合关系