1700471027
再来看看Client是如何调用的,如代码清单24-15所示。
1700471028
1700471029
代码清单24-15 场景类
1700471030
1700471031
public class Client{
1700471032
1700471033
public static void main(String[]args){
1700471034
1700471035
//定义发起人
1700471036
1700471037
Originator originator=new Originator();
1700471038
1700471039
//建立初始状态
1700471040
1700471041
originator.setState(“初始状态……”);
1700471042
1700471043
System.out.println(“初始状态是:”+originator.getState());
1700471044
1700471045
//建立备份
1700471046
1700471047
originator.createMemento();
1700471048
1700471049
//修改状态
1700471050
1700471051
originator.setState(“修改后的状态……”);
1700471052
1700471053
System.out.println(“修改后状态是:”+originator.getState());
1700471054
1700471055
//恢复原有状态
1700471056
1700471057
originator.restoreMemento();
1700471058
1700471059
System.out.println(“恢复后状态是:”+originator.getState());
1700471060
1700471061
}
1700471062
1700471063
}
1700471064
1700471065
运行结果如下所示:
1700471066
1700471067
初始状态是:初始状态……
1700471068
1700471069
修改后状态是:修改后的状态……
1700471070
1700471071
恢复后状态是:初始状态……
1700471072
1700471073
运行结果是我们所希望的,程序精简了很多,而且高层模块的依赖也减少了,这正是我们期望的效果。现在我们来考虑一下原型模式深拷贝和浅拷贝的问题,在复杂的场景下它会让你的程序逻辑异常混乱,出现错误也很难跟踪。因此Clone方式的备忘录模式适用于较简单的场景。
1700471074
1700471075
注意 使用Clone方式的备忘录模式,可以使用在比较简单的场景或者比较单一的场景中,尽量不要与其他的对象产生严重的耦合关系。
1700471076
[
上一页 ]
[ :1.700471027e+09 ]
[
下一页 ]