传值调用是指方法在调用参数时,不是对原参数进行操作,而是创建参数的拷贝并对进行操作,这种调用有利于保护数据.其在JAVA中的实现如下:
程序输出结果:
a : 0 b : 1
a : 0 b : 1
也就是说,其实方法的运行并没有改变a,b的值,让我们深入JVM的内存中看看是怎么回事: 先看看JVM的存储区
[img]http://dl.iteye.com/upload/picture/pic/77311/150d099b-6b01-3085-b7f1-1c1a1fa35a0f.jpg[/img]
对于swap(a, b)的方法调用,可以这样理解,a,b两个引用存储在Heap内,他们的int值0和1存储在Stack内,在调用swap方法时,新建了i,j两个引用
i,j也指向int值0和1,在方法内互换的是i,j所指向的值,所以a,b所指向的并未发生改变 JAVA中的方法,只能对封装在类内部的变量的值进行操作,例子:
1.MyClass类封装variable
2.测试类Test
程序输出结果 :
mc1's variable is 0
mc2's variable is 1
mc1's variable is 1
mc2's variable is 0
解析:方法的拷贝出mc1和mc2的引用mc1k和mc2k.
mc1与mc1k指向同一个实例MyClass(其中实例内的variable == 0);
mc2与mc2k指向同一个实例MyClass(其中实例内的variable == 1);
swapOne方法交换了mc1k和mc2k所指向的对象,但是mc1k和mc2k在方法结束后被JVM回收了,mc1和mc2为改变
swapTwo方法通过mc1k和mc2k互换了指向的对象MyClass里面的变量variable的值,mc1和mc2的指向的实例并未改变,但是指向的实例内的变量的值改变了,所以看起来好像是mc1和mc2所指向的实例互换了.
public class TestSwap {
public static void main(String[] args) {
int a = 0;
int b = 1;
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) {
int temp = i;
i = j;
j = temp;
}
}
程序输出结果:
a : 0 b : 1
a : 0 b : 1
也就是说,其实方法的运行并没有改变a,b的值,让我们深入JVM的内存中看看是怎么回事: 先看看JVM的存储区
[img]http://dl.iteye.com/upload/picture/pic/77311/150d099b-6b01-3085-b7f1-1c1a1fa35a0f.jpg[/img]
对于swap(a, b)的方法调用,可以这样理解,a,b两个引用存储在Heap内,他们的int值0和1存储在Stack内,在调用swap方法时,新建了i,j两个引用
i,j也指向int值0和1,在方法内互换的是i,j所指向的值,所以a,b所指向的并未发生改变 JAVA中的方法,只能对封装在类内部的变量的值进行操作,例子:
1.MyClass类封装variable
public class MyClass {
int variable = 0;
public void setVariable(int i) {
variable = i;
}
}
2.测试类Test
public class Test {
public static void main(String[] args) {
MyClass mc1 = new MyClass();
MyClass mc2 = new MyClass();
mc2.setVariable(1); // mc2.variable的值设为1
swapOne(mc1, mc2); // 这行代码等于无效
System.out.println("mc1's variable is " + mc1.variable);
System.out.println("mc2's variable is " + mc2.variable);
swapTwo(mc1, mc2); // 这行代码交换了mc1和mc2的variable的值
System.out.println("mc1's variable is " + mc1.variable);
System.out.println("mc2's variable is " + mc2.variable);
}
public static void swapOne(MyClass mc1k, MyClass mc2k) {
MyClass temp = mc1k;
mc1k = mc2k;
mc2k = temp;
}
public static void swapTwo(MyClass mc1k, MyClass mc2k) {
int temp = mc1k.variable;
mc1k.variable = mc2k.variable;
mc2k.variable = temp;
}
}
程序输出结果 :
mc1's variable is 0
mc2's variable is 1
mc1's variable is 1
mc2's variable is 0
解析:方法的拷贝出mc1和mc2的引用mc1k和mc2k.
mc1与mc1k指向同一个实例MyClass(其中实例内的variable == 0);
mc2与mc2k指向同一个实例MyClass(其中实例内的variable == 1);
swapOne方法交换了mc1k和mc2k所指向的对象,但是mc1k和mc2k在方法结束后被JVM回收了,mc1和mc2为改变
swapTwo方法通过mc1k和mc2k互换了指向的对象MyClass里面的变量variable的值,mc1和mc2的指向的实例并未改变,但是指向的实例内的变量的值改变了,所以看起来好像是mc1和mc2所指向的实例互换了.