概述:
使用原型实例指定要创建对象的类型,通过复制这个原型来创建新对象
不需要知道任何创建的细节,不调用构造函数
适用场景:
类初始化消耗较多资源
new产生的一个对象需要非常繁琐的过程(数据准备、访问权 限等 构造函数比较复杂
循环体中生产大量对象时
优点:
原型模式性能比直接new-个对象性能高
简化创建过程
缺点:
必须配备克隆方法
对克隆复杂对象或对克隆出的对象进行复杂改造时,容易引入风险
深拷贝、浅拷贝要运用得当
public abstract class Prototype {
abstract Prototype myClone();}
public class ConcretePrototype extends Prototype {
private String filed;
public ConcretePrototype(String filed) {
this.filed = filed;
}
@Override
Prototype myClone() {
return new ConcretePrototype(filed);
}
@Override
public String toString() {
return filed;
}}
public class Client {
public static void main(String[] args) {
Prototype prototype = new ConcretePrototype("abc");
Prototype clone = prototype.myClone();
System.out.println(clone.toString());
}}
abc
附:
抽象克隆方法:在一个抽象类中添加克隆接口,重写克隆方法,继承他的子类也能够进行克隆
如果使用默认的克隆方法,它是浅克隆(即虽然克隆出来的对象地址不同,但是如果克隆的对象中有引用类型的成员变量,在克隆后的对象中的对应成员变量是指向同一个变量对象地址的,修改被克隆对象的值,克隆对象的值也会随之改变)
如果要进行深克隆的话,应当在重写的克隆方法中单独克隆引用类型的成员变量。
JDK中
* java.lang.Object#clone()
实现这个模式的如:
ArrayList
HashMap<K,V>