深入理解Java中对象的浅拷贝与深拷贝
2017-02-07 22:27
495 查看
参考博客:http://blog.csdn.net/lcg910978041/article/details/51992614
理解好浅拷贝和和深拷贝对于理解Java的内存模型有很大的帮助。
在这里,我们先了解一下什么是浅拷贝和深拷贝:
1、浅拷贝:浅拷贝只是单纯的对于对象的拷贝,对象属性对于其它对象的引用并没有进行拷贝(也就是说浅拷贝创建的对象和原来对象指向不同的地址空间,但是对象属性里面对其它对象的引用【引用属性】指向的还是同一个地址空间);
2、深拷贝:深拷贝是指拷贝创造出来的对象和原来对象是完全不同的,不仅拷贝创建的对象和原来对象指向的地址不同,引用属性指向的地址空间也是不一样的。如果引用属性里面还含有引用属性,那么该引用属性指向的地址空间也是不同,一次类推……。可以理解成深拷贝是浅拷贝的递归。
记得,要想对对象实现拷贝,类必须实现Cloneable接口,并实现clone方法。
看看例子:
略作修改
通过例子可以知道,要想实现彻底深拷贝,必须在clone方法里面对对象的引用属性进行拷贝(一次类推……)
理解好浅拷贝和和深拷贝对于理解Java的内存模型有很大的帮助。
在这里,我们先了解一下什么是浅拷贝和深拷贝:
1、浅拷贝:浅拷贝只是单纯的对于对象的拷贝,对象属性对于其它对象的引用并没有进行拷贝(也就是说浅拷贝创建的对象和原来对象指向不同的地址空间,但是对象属性里面对其它对象的引用【引用属性】指向的还是同一个地址空间);
2、深拷贝:深拷贝是指拷贝创造出来的对象和原来对象是完全不同的,不仅拷贝创建的对象和原来对象指向的地址不同,引用属性指向的地址空间也是不一样的。如果引用属性里面还含有引用属性,那么该引用属性指向的地址空间也是不同,一次类推……。可以理解成深拷贝是浅拷贝的递归。
记得,要想对对象实现拷贝,类必须实现Cloneable接口,并实现clone方法。
看看例子:
public class CopyTest { @Test public void testCopy() throws CloneNotSupportedException { User u1=new User("zhangsan", 12); User u2=(User) u1.clone(); System.out.println("u1:"+u1+" "+"username:"+u1.getUsername().hashCode()); System.out.println("u2:"+u2+" "+"username:"+u2.getUsername().hashCode()); } class User implements Cloneable{ String username; int age; @Override protected Object clone() throws CloneNotSupportedException { // TODO Auto-generated method stub return super.clone(); } public User(String username, int age) { this.username = username; this.age = age; } public void setAge(int age) { this.age = age; } public int getAge() { return age; } public void setUsername(String username) { this.username = username; } public String getUsername() { return username; } } } 输出: u1:wnl.test.CopyTest$User@f2a0b8e username:-1432604556 adminator:wnl.test.CopyTest$Adminator@593634ad u2:wnl.test.CopyTest$User@20fa23c1 username:-1432604556adminator:wnl.test.CopyTest$Adminator@593634ad 这里进行的是浅拷贝,u1和u2地址空间不一样,u1.adminator与u2.adminator的地址空间一样。
略作修改
@Override protected Object clone() throws CloneNotSupportedException { User newUser = (User) super.clone(); newUser.adminator=(Adminator)adminator.clone(); return newUser; } 输出: u1:wnl.test.CopyTest$User@f2a0b8e username:-1432604556 adminator:wnl.test.CopyTest$Adminator@593634ad u2:wnl.test.CopyTest$User@20fa23c1 username:-1432604556adminator:wnl.test.CopyTest$Adminator@3581c5f3 可以看出,u1和u2,u1.adminator和u2.adminator的地址空间一样了。 但是细心的读者可以看到,username的hascode返回值一样,因为username还是进行前拷贝。
通过例子可以知道,要想实现彻底深拷贝,必须在clone方法里面对对象的引用属性进行拷贝(一次类推……)
相关文章推荐
- 深入理解Java对象序列化
- 深入理解java String 对象的不可变性
- 深入理解Java虚拟机笔记---判断对象是否存活
- 深入理解Java对象序列化
- 深入理解Java对象序列化
- 深入理解Java对象序列化lff
- 深入理解Java对象的序列化与反序列化的应用
- 深入理解Java对象序列化
- 深入理解Java对象序列化
- 深入理解java对象的序列化
- 深入理解java String 对象的不可变性
- 什么是 Java序列化,深入理解Java对象序列化
- 深入理解Java对象序列化
- Java笔记十四.深入理解类和对象(1)
- java语言学习连载(四)--深入理解面象对象
- 深入理解Java对象序列化
- 深入理解Java对象序列化
- 深入理解Java对象序列化
- 深入理解Java对象序列化
- 深入理解Java对象序列化