1700461694
//覆写父类Object方法
1700461695
1700461696
@Override
1700461697
1700461698
public PrototypeClass clone(){
1700461699
1700461700
PrototypeClass prototypeClass=null;
1700461701
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
类初始化需要消化非常多的资源,这个资源包括数据、硬件资源等。
[
上一页 ]
[ :1.700461694e+09 ]
[
下一页 ]