欢迎来到天天文库
浏览记录
ID:22021077
大小:36.00 KB
页数:5页
时间:2018-10-26
《深克隆与浅克隆》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、java中深克隆和浅克隆的用法和区别首先,说道深克隆和浅克隆我们就要了解它的具体含义1.什么是深、浅克隆呢?浅克隆:只复制一个对象,对象内部存在的指向其他对象数组或者引用则不复制。 深克隆:对象,对象内部的引用均复制。克隆的特点:1.克隆后的对象具有克隆前的对象的属性和方法。2.哪个类要克隆就要实现接口。区别:1.浅克隆:只克隆其对象的方法,不克隆属性值。现在我有一个Order对象order1,它包含了一个LineItems对象items,这表示的是有一个订单order1,订单的内容是items。好的,现在有另一个客户想要一份订单,内容跟o
2、rder1完全一样,那么在系统的逻辑层我们怎么做呢?很简单,order2=order1.clone().我们知道clone方法是在内存中生成一个新的对象,而不是只得到原对象的引用。这时候,有人说话了:“哦,明白了我们对order2的成员变量进行修改,是不会影响order1的。”很可惜,这句话只对了一半。假设order类有一个成员变量name,当然改变order2.name不会影响order1.name,因为他们在不同的内存区域。但是如果改变order1.items呢?很遗憾,简单地使用order1.clone,是会影响到order2.ite
3、ms的。原因很简单,就是因为clone方法默认的是浅克隆,即不会克隆对象引用的对象,而只是简单地复制这个引用。所以在上例中,items对象在内存中只有一个,order1和order2都指向它,任何一个对象对它的修改都会影响另一个对象。那相对浅克隆,深克隆自然就是会克隆对象引用的对象了。也就是说,在上例中,改变order1.items并不会影响order2.items了。因为内存中有两个一样的items。注意:如果实现深克隆?一个方法自然是重写clone方法,添加如order.items=(LineItems)items.clone()的语句
4、,也就是人为地添加对引用对象的复制。这个方法的缺点是如果引用对象有很多,或者说引用套引用很多重,那么太麻烦了。业界常用的方法是使用串行化然后反串行化的方法来实现深克隆。由于串行化后,对象写到流中,所有引用的对象都包含进来了,所以反串行化后,对等于生成了一个完全克隆的对象。绝!这个方法的要求是对象(包括被引用对象)必须实现了Serializable接口,否则就要用transient关键字将其排除在复制过程中。 JavaSE中深克隆和浅克隆如何去理解深克隆和浅克隆呢?首先从一个例子上来区分深克隆和浅克隆://MyObeject只是一个普通的类,
5、下面的LocalCopy是对其的调用,关键是g(),f()两个//方法的区别classMyObject implementsCloneable{ int i; MyObject(intk){ i=k; } publicObjectclone(){ Objecto= null; try{ o= super.clone(); } catch(CloneNotSupportedExceptione){ System.out.printl
6、n("MyObjectcan'tclone"); } returno; } publicStringtoString(){ returnInteger.toString(i); }}public classLocalCopy{ staticMyObjectg(MyObjectg){ g.i++; returng; } staticMyObjectf(MyObjectf){ f=(MyObject)f.clone(); //Localc
7、opy f.i++; returnf; } public static voidmain(String[]args){ MyObjecta= newMyObject(11); System.out.println("前a.i="+a.i); //以不同的方式获得了两个对象b和c MyObjectb=g(a); MyObjectc=f(a); //对b和c的属性更改其值,看看对原对象a的属性的值有没有影响 b.i=100;
8、 c.i=200; System.out.println("后a.i="+a.i); System.out.println("b.i="+b.i
此文档下载收益归作者所有