1、生活中的原型模型
生活中,快速复制,十分常见,比如小时候考试的印刷机,先通过刻版,下一步,以刻版或母版为基础进行大批量印刷。这样能快速的创建一批符合要求的对象。
变成中也十分常见,常见的有通过拷贝自身属性快速创建另一个对象。各个对象之间是相互独立的(内存空间地址不一致),
2、浅克隆、深克隆
浅克隆,即通过实现Cloneable标记接口(空接口),在浅克隆中,如果原型对象的成员变量是值类型,将复制一份给克隆对象;如果原型对象的成员变量是引用类型,则将引用对象的地址复制一份给克隆对象,也就是说原型对象和克隆对象的成员变量指向相同的内存地址。在Java语言中,通过覆盖Object类的clone()方法可以实现浅克隆。
@Data
public class WeeklyLog implements Cloneable {
private String name;
private String date;
private String content;
private Attachment attachment;
@Override
public WeeklyLog clone(){
Object obj = null;
try {
obj = super.clone();
return (WeeklyLog) obj;
} catch (CloneNotSupportedException e) {
System.out.println("不支持复制");
return null;
}
}
}
深克隆,无论原型对象的成员变量是值类型还是引用类型,都将复制一份给克隆对象,深克隆将原型对象的所有引用对象也复制一份给克隆对象。简单来说,在深克隆中,除了对象本身被复制外,对象所包含的所有成员变量也将复制。需要克隆类以及其成员变量类均需要实现Serializable序列化接口。实际调用时,通过输入输出流进行转换,从而保证成员变量类中的引用地址不一致,这样才能保证深克隆。
@Data
public class DeepWeeklyLog implements Serializable {
private static final long serialVersionUID = 6273894595305648546L;
private Attachment attachment;
private String name;
private String Date;
private String content;
public DeepWeeklyLog deepClone() throws IOException, ClassNotFoundException {
//将对象写入流中
ByteArrayOutputStream bao = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(bao);
oos.writeObject(this);
//将对象从流中取出
ByteArrayInputStream bis = new ByteArrayInputStream(bao.toByteArray());
ObjectInputStream ois = new ObjectInputStream(bis);
return (DeepWeeklyLog) ois.readObject();
}
}
3、原型模型实现及其优点
原型管理器(Prototype Manager)是将多个原型对象存储在一个集合中供客户端使用,它是一个
专门负责克隆对象的工厂,其中定义了一个集合用于存储原型对象,如果需要某个原型对象
的一个克隆,可以通过复制集合中对应的原型对象来获得。在原型管理器中针对抽象原型类
进行编程,以便扩展。

其中原型管理器可以通过单例模式来实现,如饿汉、懒汉