Java在进行参数传递的时候和c++不一样,并没有显式指定传递的是参数的值还是引用,所以通过下面一个程序可以直观得出一些结论:
public class core {
public static void main(String[] argv)
{
int a = 3;
String b = "abc";
int[] c = {1,2,3,4,5};
Integer d = 3;
A e = new A(5);
func1(a,b,c,d,e);
System.out.println("a:"+a+" b:"+b+" c:"+ Arrays.toString(c)+" d:"+d+" e:"+e.getA());
}
public static void func1(int a, String b, int[] c, Integer d, A e)
{
a = 4;
b = "123";
c[0] = 2;
d = 5;
e.setA(10);
}
}
class A
{
private int a;
A(int a)
{
this.a = a;
}
public void setA(int a)
{
this.a = a;
}
public int getA() {
return a;
}
}
输出结果为:
a:3 b:abc c:[2, 2, 3, 4, 5] d:3 e:10
可以发现如下规律:
1.对于八大基本类型(如int)及其封装类(如Integer),型参传递的是值,因此并不会引起实参的改变;
2.对于字符串String类型,也不会引起实参的改变;
3.对于数组类型,传递的是引用,会引起实参的变化;
4.对于对象实例,传递的也是引用,会改变实参;
Note:但实例对象并不是所有情况都改变的,例如自定义一个swap函数交换两个对象,如下:
public void swap(A x, A y)
{
A temp = x;
x = y;
y = temp;
}
这种情况两个实参对象是不会交换的,因为swap方法的参数x和y被初始化为两个引用对象的拷贝,这个方法是交换两个拷贝,而在方法结束时参数变量x和y被丢弃了。原来传递进来的实参调用之前所引用的对象。
欢迎补充和纠正。