值传递:方法调用时,实际参数把它的值传递给对应的形式参数,方法执行中形式参数值的改变不影响实际参 数的值。
引用传递:也称为传地址。方法调用时,实际参数的引用(地址,而不是参数的值)被传递给方法中相对应的形式参数,在方法执行中,对形式参数的操作实际上就是对实际参数的操作,方法执行中形式参数值的改变将会影响实际参数的值。
看下面的代码
值传递
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 class Test{ 2 public static void main(String[] args){ 3 V v1 = new V(); 4 v1.i = 10; 5 handler(v1,30); 6 System.out.println("v1:"+v1.i); 7 } 8 public static void handler(V v,int i){ 9 v.i = i; 10 V v8 = new V(); 11 v = v8; 12 System.out.println(v.i); 13 } 14 } 15 class V{ 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