值传递:方法调用时,实际参数把它的值传递给对应的形式参数,方法执行中形式参数值的改变不影响实际参 数的值。
引用传递:也称为传地址。方法调用时,实际参数的引用(地址,而不是参数的值)被传递给方法中相对应的形式参数,在方法执行中,对形式参数的操作实际上就是对实际参数的操作,方法执行中形式参数值的改变将会影响实际参数的值。
看下面的代码
值传递
public class PassValueTest {
public static void main(String[] args){
int a = 10;
int b = 20;
System.out.println("a="+a+",b="+b);
swap(a,b);
System.out.println("a="+a+",b="+b);
}
public static void swap(int i,int j){
System.out.println("i="+i+",j="+j);
int temp;
temp = j;
j = i;
i = temp;
System.out.println("i="+i+",j="+j);
}
}
输出结果为
a=10,b=20
i=10,j=20
i=20,j=10
a=10,b=20
说明方法执行中形式参数值的改变不影响实际参 数的值。
再来看一下引用传递
1 public classTest{2 public static voidmain(String[] args){3 V v1 = newV();4 v1.i = 10;5 handler(v1,30);6 System.out.println("v1:"+v1.i);7 }8 public static void handler(V v,inti){9 v.i =i;10 V v8 = newV();11 v =v8;12 System.out.println(v.i);13 }14 }15 classV{16 public int i = 1;17 }
这个就比较有意思了 它的输出结果为:
1
v1:30
因为第五行
handler(v1,30);的时候其实是有两个引用 v和v1都指向该对象的引用,也就是实际的堆内存,所以v直接操作此对象将i改为30,第11行v=v8,v又去指向新的内存地址了,不会对v1产生影响 所以v1.i还是30