之所以把这个问题拿出来重新分析一次,是因为我们操作Java的对象(Object)全是通过对象的引用(Object references),引用可以理解为指针,容易让人对应到C++的传址上面去。讨论讨论有百益而无一害嘛。
在传基本数据类型 变量时,直接传值不会让人费解;但当传递对象时,就应该理解为传递的是对象引用的值,但这个值并不是对象本身,而是指向该对象,即你让另一个引用指向了该对象。
--Java以By Value的方式传递Object reference。
以下面简单程序为例:
package test;
public class BlogTest
{
public void modifyAAA(int x, java.util.ArrayList list)
{
x += 5;
System.out.println("x=====" + x);
list.add(new java.util.Date());
System.out.println(list.size());
}
public static void main(String[] args)
{
BlogTest blogtest = new BlogTest();
int i = 5;
java.util.ArrayList list = new java.util.ArrayList();
System.out.println("i=======" + i);
System.out.println("list.size()==="+list.size());
blogtest.modifyAAA(i, list);
System.out.println("i==new==" + i);
System.out.println("list.size()====" + list.size());
}
}
/*
运行得到的结果是这样的
i=======5
list.size()===0
x=====10
1
i==new==5
list.size()==new==1
*/
这说明在参数传递过程中发生了以下事情:int 变量 i 被复制了一份给 int x,在modifyAAA()方法中改变了x的值并不会影响主函数中i的值,当然,这是变量生存区间不同,很好理解。但发现list对象的引用传到modifyAAA()方法的前后,主函数中的list也跟着发生了变化。这正说了在传递对象引用时,形参得到了实参对象的引用拷贝,两个引用都指向了同一list对象,所以形参改变了list同时也能反映到实参中来。