模式定义:


用原型实例指定创建对象的种类,并且通过复制这些原型创建新的对象。原型模式允许一个对象再创建另外一个可定制的对象,无须知道任何创建的细节。


应用场景:


(1) ​​ctrl c, ctrl v​​ 复制,粘贴

(2) struct2 创建action 对象

  在Struts2中为了保证线程的安全性,Action对象的创建使用了原型模式,访问一个已经存在的Action对象时将通过克隆的方式创建出一个新的对象,从而保证其中定义的变量无须进行加锁实现同步

(3) Spring 可采用原型模式创建Bean类

  在Spring中,用户也可以采用原型模式来创建新的bean实例,从而实现每次获取的是通过克隆生成的新实例,对其进行修改时对原有实例对象不造成任何影响

(4)参数传入。

  参数传入。若传入的参数类似List(操作后可能会改变内部排序,数据等等),而又不想其改变,那么就clone一个传入。————(忘了再哪本书上看到的。。。)


模式实现:


浅克隆 :

属性均为基本类型

【23种设计模式】之 原型模式(Prototype Pattern)_设计模式


【23种设计模式】之 原型模式(Prototype Pattern)_spring_02


倘若有个复杂属性

【23种设计模式】之 原型模式(Prototype Pattern)_prototype_03


【23种设计模式】之 原型模式(Prototype Pattern)_原型_04


所以浅​​clone​

【23种设计模式】之 原型模式(Prototype Pattern)_设计模式_05




深克隆 :

【23种设计模式】之 原型模式(Prototype Pattern)_prototype_06


【23种设计模式】之 原型模式(Prototype Pattern)_prototype_07


所以深​​clone​

【23种设计模式】之 原型模式(Prototype Pattern)_原型_08


底层原理:

前言:虽然clone是native,但也阻挡不了我们想象,(^__^) 嘻嘻……

(1) 要clone的对象已在内存中,所以直接从内存中读取字节码数组,然后利用(javasist,asm等框架)动态生成。

(2)将要clone的对象,写入流,再从流中读取生成。例如下面:

public Object deepClone() throws IOException, ClassNotFoundException, OptionalDataException {
//将对象写入流中
ByteArrayOutputStream bao=new ByteArrayOutputStream();
ObjectOutputStream oos=new ObjectOutputStream(bao);
oos.writeObject(this);

//将对象从流中取出
ByteArrayInputStream bis=new ByteArrayInputStream(bao.toByteArray());
ObjectInputStream ois=new ObjectInputStream(bis);
return(ois.readObject());
}