原型模式之 深复制和浅复制

浅复制

  被复制对象的所有变量都含有与原对象相同的值,而且对其他对象的引用仍然是指向原来的对象。即 浅复制只负责当前对象实例,对引用的对象不做复制。

 

深复制

  被复制对象的所有的变量都含有与原来对象相同的值,除了那些引用其他对象的变量。那些引用其他对象的变量将指向一个被复制的新对象,而不再是原有那些被引用对象。即 深复制把要复制的对象所引用的对象也都复制了一次,而这种对被引用到的对象复制叫做间接复制。

  深复制要深入到多少层,是一个不确定的问题。在决定以深复制的方式复制一个对象的时候,必须决定对间接复制的对象是采取浅复制还是深复制还是继续采用深复制。因此,在采取深复制时,需要决定多深才算深。此外,在深复制的过程中,很可能会出现循环引用的问题。

 

利用Cloneable的clone克隆方法实现浅复制

  在Cloneable接口中有一个clone方法,需要实现复制行为的类,只要实现Cloneable接口,就具有了自我克隆的能力,而这种克隆的就是浅复制的代表。

 

利用串行化来做深复制

  把对象写到流里的过程称之为串行化(Serilization)过程,但在业界又将串行化这一过程形象的称为“冷冻”或“腌咸菜”过程;而把对象从流里面读出来的并行化(Deserialization)过程称为“解冻”或“回鲜”过程。应该注意的是,写到流的对象是一个拷贝,而原对象仍然存在于JVM里面,因此“冷冻”的只是一个对象的拷贝。

 

public Object deepClone(){
 //将对象写到流里 
ByteArrayOutputStream bo = new ByteArrayOutputStream(); ObjectOutputStream oo = new ObjectOutputStream(bo); oo.writeObject(this); 
//将对象从流中读出来 ByteArrayInputStream bi = new ByteArrayInputStream(bo.toByteArray()); 
ObjectInputStream oi= new ObjectInputStream(bi); 
return (oi.readObject()); 
}

 

 这样做的前提是对象以及对象内部所有引用到的对象都是可串行化的,否则,就需要仔细考虑那些不可串行话的对象可否设成transient,从而将之排除在复制过程之外。

 

 

你可能感兴趣的:(jvm,OO)