使用场景:当通过new产生的一个对象需要非常繁琐的数据准备或访问权限时,可以使用原型模式。
类似于java中的克隆技术,以某个对象为原型,复制出新的对象。新对象与原型对象拥有相同特点。
优势:效率高,避免了重新执行构造过程的步骤。
与new出来的对象的比较:
new创建新的对象属性采用的是默认值。克隆出的对象的属性值完全和原型对象相同。
克隆出的新对象改变不会影响原型对象,并且修改克隆对象的值不影响原型对象。
浅复制:修改原型和克隆修改任意一个对象的属性,都影响对方,因为2个内存地址值指向同一对象
public class LightPrototype implements Cloneable{
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "LightPrototype [name=" + name + "]";
}
public LightPrototype(String name) {
super();
this.name = name;
}
public LightPrototype() {
super();
}
@Override
protected Object clone() throws CloneNotSupportedException {
Object o = super.clone();
return o;
}
}
深复制:修改原型和克隆修改任意一个对象的属性,不影响其他对象的属性值
public class DeepPrototype implements Cloneable{
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "DeepPrototype [name=" + name + "]";
}
public DeepPrototype(String name) {
super();
this.name = name;
}
public DeepPrototype() {
super();
}
@Override
protected Object clone() throws CloneNotSupportedException {
Object o = super.clone();
DeepPrototype d = (DeepPrototype)o;
d.name = (String) this.name.clone();
return o;
}
}