解释参数在方法中的传递过程,并通过内存解析图的 方式,描绘出方法执行时内存的变化。
可以使用今天课堂代码来解释
public class Demo11 {
void fun1(int i, int j) {
i = i + 5;
j = j + 5;
System.out.println("fun1-i:" + i);
System.out.println("fun1-j:" +j);
}
}
public static void main(String[] args) {
Demo11 demo11 = new Demo11();
int i=10;
int j=20;
demo11.fun1(i, j);
System.out.println("main-i:" + i);
System.out.println("main-j:" + j);
System.out.println("====================");
}
}
此方法最后的输出是:
fun1-i:15
fun1-j:25
main-i:10
main-j:20
理解:当代码执行到int i = 10;int j = 20;时,相当于在栈区内开辟了一块空间来存储这两个值,因此执行System.out.println(“main-i:” + i); System.out.println(“main-j:” + j);这两个语句时,相当于直接调用栈区的这两个值。而其后到fun1()方法时,相当于把i,j的值调用过去,然后在栈区开辟心的空间来存储新的值,这个值与原来的从而fun输出的值是新值15,25;
public class Demo11 {
void fun1(P p) {
p.i = p.i + 5;
p.j = p.j + 5;
System.out.println("fun1-p-i:" + p.i);
System.out.println("fun1-p-j:" + p.j);
}
public static void main(String[] args) {
Demo11 demo11 = new Demo11();
P p= new P();
p.i =10;
p.j =20;
demo11.fun1(p);
System.out.println("main-p-i:" + p.i);
System.out.println("main-p-j:" + p.j);
}
}
class P {
int i;
int j;
}
解释:这个属于引用类型的数据传递。P p = new p()可以理解为,在堆区开辟一片空间用来存储定义值得地址。当p.i=10;p.j=20;时,堆区内存中被赋予i=i;j=20;当执行到p.i+5和p.j+5时,堆区内重新开辟一块空间用来存储p.i+5和p.j+5的值。因此,输出p.ihep.j的值,是10和20;