深拷贝与浅拷贝的区别
1.浅复制与深复制概念
⑴浅复制(浅克隆)
⑵深复制(深克隆)
被复制对象的所有变量都含有与原来的对象相同的值,除去那些引用其他对象的变量。那些引用其他对象的变量将指向被复制过的新对象,而不再是原有的那些被引用的对象。换言之,深复制把要复制的对象所引用的对象都复制了一遍。
2.Java的clone()方法
⑴clone方法将对象复制了一份并返回给调用者。一般而言,clone()方法满足:
①对任何的对象x,都有x.clone() !=x//克隆对象与原对象不是同一个对象
②对任何的对象x,都有x.clone().getClass()= =x.getClass()//克隆对象与原对象的类型一样
③如果对象x的equals()方法定义恰当,那么x.clone().equals(x)应该成立。
⑵Java中对象的克隆
①为了获取对象的一份拷贝,我们可以利用Object类的clone()方法。
②在派生类中覆盖基类的clone()方法,并声明为public。
③在派生类的clone()方法中,调用super.clone()。
④在派生类中实现Cloneable接口。
被复制对象的所有变量都含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原来的对象。换言之,浅复制仅仅复制所考虑的对象,而不复制它所引用的对象。
3.利用串行化来做深复制
把 对象写到流里的过程是串行化(Serilization)过程,但是在Java程序师圈子里又非常形象地称为“冷冻”或者“腌咸菜(picking)”过 程;而把对象从流中读出来的并行化(Deserialization)过程则叫做“解冻”或者“回鲜(depicking)”过程。应当指出的是,写在流 里的是对象的一个拷贝,而原对象仍然存在于JVM里面,因此“腌成咸菜”的只是对象的一个拷贝,Java咸菜还可以回鲜。
在Java语言里深复制一个对象,常常可以先使对象实现Serializable接口,然后把对象(实际上只是对象的一个拷贝)写到一个流里(腌成咸菜),再从流里读出来(把咸菜回鲜),便可以重建对象。
package test;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import com.ufgov.lm.common.domain.entity.LmBuildUnit;
/**
* @ClassName: DeepCopy
* @Description: 深拷贝
* @author zengfh
* @date 2013-10-16 下午2:34:45
*/
public class DeepCopy {
/**
* @Title: deepCopy
* @Description: 利用序列化来做深复制,把对象写到流里的过程是序列化(Serilization)过程,
* 而把对象从流中读出来的过程则叫做反序列化(Deserialization)过程
* @param @param src
* @param @return dest
* @param @throws IOException
* @param @throws ClassNotFoundException
* @return Object
* @throws
*/
public Object deepCopy(Object src) throws IOException, ClassNotFoundException {
ByteArrayOutputStream byteOut = new ByteArrayOutputStream();
ObjectOutputStream out = new ObjectOutputStream(byteOut);
out.writeObject(src);
out.flush();
ByteArrayInputStream byteIn = new ByteArrayInputStream(byteOut.toByteArray());
ObjectInputStream in = new ObjectInputStream(byteIn);
Object dest = in.readObject();
out.close();
in.close();
return dest;
}
public static void main(String[] args) {
DeepCopy deepCopy = new DeepCopy();
LmBuildUnit bean = new LmBuildUnit();
bean.setBuildUnitCode("01");
bean.setBuildUnitName("aaaa");
try {
LmBuildUnit bean2 = (LmBuildUnit) deepCopy.deepCopy(bean);
System.out.println(bean2.getBuildUnitCode() + "------------"
+ bean2.getBuildUnitName());
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
1386

被折叠的 条评论
为什么被折叠?



