java克隆
来源:互联网 发布:数控锥度编程 编辑:程序博客网 时间:2024/06/05 20:30
why:
今天一直很纠结为什么Java里面有个clone()方法,复制对象时直接“=”不就行了,为什么还要在每个类里面重写clone方法。
Google了下,发现这个是典型的先学C/C++后再学JAVA遇到的问题,原来在JAVA中默认的“=”赋值操作,其实是将一个引用复制过去了,二者指向的还是同一块内存
gogoing:
有时候,我们需要把对象A的所有值复制给对象B(B = A),但是这样用等号给赋值你会发现,当B中的某个对象值改变时,同时也会修改到A中相应对象的值!
也许你会说,用clone()不就行了?!你的想法只对了一半,因为用clone()时,除了基础数据和String类型的不受影响外,其他复杂类型(如集合、对象等)还是会受到影响的!除非你对每个对象里的复杂类型又进行了clone(),但是如果一个对象的层次非常深,那么clone()起来非常复杂,还有可能出现遗漏!
既然用等号和clone()复制对象都会对原来对象产生影响,那么应该怎么做才能实现复制后的对象不对原来对象有任何影响呢?
其实很简单,用对象的深度克隆,这种克隆实现了克隆后的对象和原来的对象是独立开来的!
对象的深度克隆原理:将对象序列化后写在输出流里,因为写在流里面的对象是一份拷贝,原对象仍然在JVM里;然后再把输出流转换为输入流,把对象反序列化后写出来!这样就实现了对象的深度克隆,克隆后的两个对象完全独立开来,互不影响!
你会发现对象的深度克隆其实是利用的对象的序列化和反序列化,所以要进行深度克隆的对象都要实现Serializable接口!
进行深度克隆的实现代码如下:
public Object copy() throws IOException, ClassNotFoundException{
ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(bos);
oos.writeObject(this);
ObjectInputStream ois = new ObjectInputStream(new ByteArrayInputStream(bos.toByteArray()));
return ois.readObject();
}
- java 克隆
- java克隆
- java克隆
- JAVA克隆
- java 克隆
- JAVA 克隆
- java 克隆
- Java 克隆
- java 克隆
- Java克隆
- JAVA克隆
- Java克隆
- Java 克隆
- Java-克隆
- Java-克隆
- java克隆
- java克隆
- java克隆
- 关于HDFS理解
- HDU 4923 Room and Moor【栈】【想法】
- SVM另讲
- HDU-6102 GCDispower(莫比乌斯函数+树状数组)
- day25(单例模式,多线程通信,线程组,线程状态,线程池,工厂模式)
- java克隆
- 解决安装php过程中出现的问题
- JavaScript 函数++
- PE安装及制作教程
- 表达式求值
- HDOJ 基础动归汇总 ,持续更新题目,一路打怪升级
- IDEA中Maven报错NoClassDefFoundError
- 《大话数据结构》学习笔记--chapter 6
- 关于Spring MVC中的表单标签库的使用