很简单,一个原型类,只需要实现Cloneable接口,覆写clone方法,此处clone方法可以改成任意的名称,因为Cloneable接口是个空接口,你可以任意定义实现类的方法名,如cloneA或者cloneB,因为此处的重点是super.clone()这句话,super.clone()调用的是Object的clone()方法,而在Object类中,clone()是native的,具体怎么实现,我会在另一篇文章中,关于解读Java中本地方法的调用,此处不再深究。在这儿,我将结合对象的浅复制和深复制来说一下,首先需要了解对象深、浅复制的概念:
浅复制:将一个对象复制后,基本数据类型的变量都会重新创建,而引用类型,指向的还是原对象所指向的。
深复制:将一个对象复制后,不论是基本数据类型还有引用类型,都是重新创建的。简单来说,就是深复制进行了完全彻底的复制,而浅复制不彻底。
此处,写一个深浅复制的例子:
package designPattern;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
public class PrototypeDemo implements Cloneable, Serializable {
private static final long serialVersionUID = -7328443986884690052L;
private String string;
private int id;
private HashMap<String,String> map = new HashMap<String,String>();
/* 浅复制 */
public PrototypeDemo clone() throws CloneNotSupportedException {
return (PrototypeDemo) super.clone();
}
/* 深复制 */
public Object deepClone() throws IOException, ClassNotFoundException {
/* 写入当前对象的二进制流 */
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(bos);
oos.writeObject(this);
/* 读出二进制流产生的新对象 */
ByteArrayInputStream bis = new ByteArrayInputStream(bos.toByteArray());
ObjectInputStream ois = new ObjectInputStream(bis);
return ois.readObject();
}
public String getString() {
return string;
}
public void setString(String string) {
this.string = string;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public HashMap<String, String> getMap() {
return map;
}
public void setMap(HashMap<String, String> map) {
this.map = map;
}
public static void main(String[] args) throws CloneNotSupportedException, IOException, ClassNotFoundException{
PrototypeDemo d1 = new PrototypeDemo();
d1.setString("hehe");
d1.setId(1);
Map<String,String> map = d1.getMap();
map.put("sex", "男");
PrototypeDemo d2 = d1.clone();
PrototypeDemo d3 = (PrototypeDemo)d1.deepClone();
map.put("sex", "女");
System.out.print(d1.getString() + " ");
System.out.print(d1.getId() + " ");
System.out.print(d1.getMap().get("sex") + " \n");
System.out.print(d2.getString() + " ");
System.out.print(d2.getId() + " ");
System.out.print(d2.getMap().get("sex") + " \n");
System.out.print(d3.getString() + " ");
System.out.print(d3.getId() + " ");
System.out.print(d3.getMap().get("sex") + " \n");
}
}