浅析Java的“克隆”方法

发表于:2007-06-22来源:作者:点击数: 标签:
下一页 1 2 3 4 5 6 7 8 Java 语言的一个优点就是取消了指针的概念,但也导致了许多 程序员 在编程中常常忽略了对象与引用的区别,本文会试图澄清这一概念。并且由于Java不能通过简单的赋值来解决对象复制的问题,在 开发 过程中,也常常要要应用clone()方

下一页 1 2 3 4 5 6 7 8 

   Java语言的一个优点就是取消了指针的概念,但也导致了许多程序员在编程中常常忽略了对象与引用的区别,本文会试图澄清这一概念。并且由于Java不能通过简单的赋值来解决对象复制的问题,在开发过程中,也常常要要应用clone()方法来复制对象。

本文会让你了解什么是影子clone与深度clone,认识它们的区别、优点及缺点。

  看到这个标题,是不是有点困惑:Java语言明确说明取消了指针,因为指针往往是在带来方便的同时也是导致代码不安全的根源,同时也会使程序的变得非常复杂难以理解,滥用指针写成的代码不亚于使用早已臭名昭著的"GOTO"语句。Java放弃指针的概念绝对是极其明智的。但这只是在Java语言中没有明确的指针定义,实质上每一个new语句返回的都是一个指针的引用,只不过在大多时候Java中不用关心如何操作这个"指针",更不用象在操作C++的指针那样胆战心惊。唯一要多多关心的是在给函数传递对象的时候。如下例程:

clearcase/" target="_blank" >cc66 width="90%" align=center bgColor=#e6e4dd border=1>
package reference;
class Obj{
 String str = "init value";
 public String toString(){
  return str;
 }
}
public class ObjRef{
 Obj aObj = new Obj();
 int aInt = 11;
 public void changeObj(Obj inObj){
  inObj.str = "changed value";
 }
 public void changePri(int inInt){
  inInt = 22;
 }
 public static void main(String[] args)
 {
  ObjRef oRef = new ObjRef();

  System.out.println("Before call changeObj() method: " + oRef.aObj);
  oRef.changeObj(oRef.aObj);
  System.out.println("After call changeObj() method: " + oRef.aObj);

  System.out.println("==================Print Primtive=================");
  System.out.println("Before call changePri() method: " + oRef.aInt);
  oRef.changePri(oRef.aInt);
  System.out.println("After call changePri() method: " + oRef.aInt);
 }
}

/* RUN RESULT
Before call changeObj() method: init value
After call changeObj() method: changed value
==================Print Primtive=================
Before call changePri() method: 11
After call changePri() method: 11

*
*/

  这段代码的主要部分调用了两个很相近的方法,changeObj()和changePri()。唯一不同的是它们一个把对象作为输入参数,另一个把Java中的基本类型int作为输入参数。并且在这两个函数体内部都对输入的参数进行了改动。看似一样的方法,程序输出的结果却不太一样。changeObj()方法真正的把输入的参数改变了,而changePri()方法对输入的参数没有任何的改变。

原文转自:http://www.ltesting.net