一、什么是原型模式

    原型模式是一种对象创建型模式,它采取复制原型对象的方法来创建对象的实例。使用原型模式创建的实例,具有与原型一样的数据。


二、原型模式的特点

    1、由原型对象自身创建目标对象。也就是说,对象创建这一动作发自原型对象本身。

    2、目标对象是原型对象的一个克隆。也就是说,通过Prototype模式创建的对象,不仅仅与原型对象具有相同的结构,还与原型对象具有相同的值。

    3、根据对象克隆深度层次的不同,有浅度克隆与深度克隆。


三、原型模式应用场景

    1、在创建对象的时候,我们不只是希望被创建的对象继承其基类的基本结构,还希望继承原型对象的数据。

    2、希望对目标对象的修改不影响既有的原型对象(深度克隆的时候可以完全互不影响)。

    3、隐藏克隆操作的细节。很多时候,对对象本身的克隆需要涉及到类本身的数据细节。


四、原型模式代码实现

    1、需要实现Cloneable接口,重写clone方法

    2、如果需要深度克隆,需要把引用类型也克隆

Person类:

public class Person implements Cloneable{

private String name;

private int age;

private ArrayList<String> fiendNames = new ArrayList<>();


public Person(String name, int age) {
this.name = name;
this.age = age;
}


@Override
protected Person clone() throws CloneNotSupportedException {
Person clone = (Person) super.clone();
//深度克隆,需要把引用的对象也克隆一边
ArrayList cloneFiendNames = (ArrayList)clone.getFiendNames().clone();
clone.setFiendNames(cloneFiendNames);
return clone;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public int getAge() {
return age;
}

public void setAge(int age) {
this.age = age;
}

public ArrayList<String> getFiendNames() {
return fiendNames;
}

public void setFiendNames(ArrayList<String> fiendNames) {
this.fiendNames = fiendNames;
}
}

客户端:

public class MainClass {

public static void main(String[] args) throws CloneNotSupportedException {
Person person = new Person("张三",23);
ArrayList<String> list = new ArrayList<>();
list.add("T-Mac");
list.add("James");
person.setFiendNames(list);

Person clone = person.clone();

System.out.println("person name : " +person.getName() + " , clone name : " + clone.getName());
System.out.println("person age : " +person.getAge() + " , clone age : " + clone.getAge());
System.out.println("person fiends : " +person.getFiendNames() + " , clone fiends : " + clone.getFiendNames());


clone.setName("李四");
clone.setAge(24);
ArrayList<String> fiendNames = clone.getFiendNames();
fiendNames.add("Yao");
System.out.println("===========clone set name ,age================================");
System.out.println("person name : " +person.getName() + " , clone name : " + clone.getName());
System.out.println("person age : " +person.getAge() + " , clone age : " + clone.getAge());
System.out.println("person fiends : " +person.getFiendNames() + " , clone fiends : " + clone.getFiendNames());

}
}

运行结果:

五、原型模式(Prototype)_原型对象