这可能会让一部分人搞不清了。为什么呢?因为是对象地址的副本"值传递",在modify1中e=new Example();实际上e仅仅是保存ex对象地址的副本的一个句柄,当对e赋值时仅仅是对堆栈中e的赋值(对ex指针副本的变量e赋值),而并没有改变ex的句柄的指向,当方法调用完毕堆栈弹出,e就将要被垃圾回收,没有任何用处。当然你可以将它作为返回值,这就是另外一回事了。 这里比较绕,如果你能明白这个原理,那么你就可以写出合理并且高效的程序,并且可以避免一些潜在的逻辑错误,如:对象在方法中被改动了,可能你还不知道!记住c++在这一点上和java有很大的不同,c++默认的是值传递,行参会按照位复制实参(如果用指针或者引用就和java很类似了),在方法中作为参数传递对象,java更象是c++中传递引用,当然还是有区别的,那就是c++中对象的引用不可再赋值为另一个对象。 引申到克隆技术java中的所有对象都是Object类的子类,Object类定义了protected clone()方法,它的作用和c++中按位复制是一样的,因此同样会带来如果对象中包含另一个对象(注意是对象不是基本数据类型,基本数据类型直接就会被复制)的指针(java中的句柄),clone并没有将被包含的对象clone,而是复制了被包含对象的句柄或者说指针。 |
正在阅读:java中传值及引伸深度克隆的思考java中传值及引伸深度克隆的思考
2004-06-28 10:06
出处:CSDN
责任编辑:linjixiong
键盘也能翻页,试试“← →”键