java对象引用堆栈

import java.util.Scanner;
import java.util.ArrayList;
 
public class HelloJava {
public static void main(String[] args){
Num n1 = new Num();
Num n2 = n1; // n1和n2引用同一对象,即它们有相同的引用值  
n1.i = 0;
int x = 10;
System.out.println("调用方法method1前:n1.i = "+n1.i+"\tn2.i = "+n2.i+"\tx = "+x);
method1(n1,x);
System.out.println("调用方法method1后:n1.i = "+n1.i+"\tx = "+x);
System.out.println((n1 == n2) ? "n1和n2引用同一对象" : "n1和n2引用不同对象");
method2(n2);
System.out.println("调用method2后:n1.i = "+n1.i+"        n2.i = "+n2.i);
System.out.println((n1 == n2) ? "n1和n2引用同一对象" : "n1和n2引用不同对象");

}
static void method1(Num num,int y){
num.i += y;
y --;
System.out.println("在退出method方法时:num.i = "+num.i+"\ty = "+y);
}
static void method2(Num num){
num = new Num();
num.i += 100;
System.out.println("退出method方法时: num.i = "+num.i);
}
}
class Num{
int i;

}

首先创建了class Num的两个对象,将n1赋给n2。所以n1和n2有着相同的引用值,,它们都引用着同一对象。

对于method1方法来说,将n1的·值传递给了形参num,与n2和n1的关系同理。。

所以说在method1方法中对象num成员内容的任何改动,都会引起n1的内容改动。同时n1的变动也会引起n2的变动。

而x传给y是值传递,所以y的变化则不会引起x的变化。

对于method2来说,在它的函数体内重新申请了num的引用值,所以说对象num'的内容变动就不会再引起n2中内容的变化。

运行结果如下:


调用方法method1前:n1.i = 0 n2.i = 0x = 10
在退出method方法时:num.i = 10 y = 9
调用方法method1后:n1.i = 10 x = 10
n1和n2引用同一对象
退出method方法时: num.i = 100
调用method2后:n1.i = 10        n2.i = 10
n1和n2引用同一对象


猜你喜欢

转载自blog.csdn.net/qq_36273200/article/details/80988973