1700461702
try{
1700461703
1700461704
prototypeClass=(PrototypeClass)super.clone();
1700461705
1700461706
}catch(CloneNotSupportedException e){
1700461707
1700461708
//异常处理
1700461709
1700461710
}
1700461711
1700461712
return prototypeClass;
1700461713
1700461714
}
1700461715
1700461716
}
1700461717
1700461718
实现一个接口,然后重写clone方法,就完成了原型模式!
1700461719
1700461720
1700461721
1700461722
1700461724
设计模式之禅 13.3 原型模式的应用
1700461725
1700461726
13.3.1 原型模式的优点
1700461727
1700461728
❑性能优良
1700461729
1700461730
原型模式是在内存二进制流的拷贝,要比直接new一个对象性能好很多,特别是要在一个循环体内产生大量的对象时,原型模式可以更好地体现其优点。
1700461731
1700461732
❑逃避构造函数的约束
1700461733
1700461734
这既是它的优点也是缺点,直接在内存中拷贝,构造函数是不会执行的(参见13.4节)。优点就是减少了约束,缺点也是减少了约束,需要大家在实际应用时考虑。
1700461735
1700461736
1700461737
1700461738
1700461739
设计模式之禅 13.3.2 原型模式的使用场景
1700461740
1700461741
❑资源优化场景
1700461742
1700461743
类初始化需要消化非常多的资源,这个资源包括数据、硬件资源等。
1700461744
1700461745
❑性能和安全要求的场景
1700461746
1700461747
通过new产生一个对象需要非常繁琐的数据准备或访问权限,则可以使用原型模式。
1700461748
1700461749
❑一个对象多个修改者的场景
1700461750
1700461751
一个对象需要提供给其他对象访问,而且各个调用者可能都需要修改其值时,可以考虑使用原型模式拷贝多个对象供调用者使用。
[
上一页 ]
[ :1.700461702e+09 ]
[
下一页 ]