概念:
用原型实例指定创建对象的种类,并通过拷贝这些原型创建新的对象。
基于内存二进制流进行复制,不需要再经历耗时的对象初始化过程(不调用构造函数),可以提升性能。
原型模式的使用场景:
1、创建对象成本较大(比如:占用CPU太多,消耗网络资源太多等)。
2、系统中多处使用该类对象,且各个调用者都需要给它的属性重新赋值。
3、创建对象过程比较繁琐(比如数据准备、访问权限等)。
优点:
性能提高。
逃避构造函数的约束。
缺点:
配备克隆方法需要对类的功能进行通盘考虑,这对于全新的类不是很难,但对于已有的类不一定很容易,特别当一个类引用不支持串行化的间接对象,或者引用含有循环结构的时候。
必须实现Cloneable接口。
原型模式UML图:
原型模式类似于现实世界的细胞分裂
代码如下:
public class Prototype<T extends Prototype> implements Cloneable{ public T clone() { T prototype = null; try { prototype = (T)super.clone(); } catch (CloneNotSupportedException e) { e.printStackTrace(); } return prototype; } }
public class ConcretePrototype extends Prototype<ConcretePrototype> { public ConcretePrototype() { System.out.println("构造方法"); } public void show() { System.out.println("原型模式实现类"+this.hashCode()); } }
public class PrototypeDemo { public static void main(String[] args) { ConcretePrototype concretePrototype = new ConcretePrototype(); for(int i=0;i<10;i++) { ConcretePrototype cloneConcretePrototype = concretePrototype.clone(); cloneConcretePrototype.show(); } } }
输出:
构造方法 原型模式实现类685325104 原型模式实现类460141958 原型模式实现类1163157884 原型模式实现类1956725890 原型模式实现类356573597 原型模式实现类1735600054 原型模式实现类21685669 原型模式实现类2133927002 原型模式实现类1836019240 原型模式实现类325040804
深克隆和浅克隆:
浅克隆:只负责克隆按值传递的数据
深克隆:除了浅克隆要克隆的值外,还负责克隆引用类型的数据,基本上所有属性数据都会被克隆出来
原型模式属于深克隆。