文
章
目
录
章
目
录
关于“ java是按值传递还是按引用传递?”一直存在很多争论。”。好吧,让我们上次总结一下,Java 是按值传递而不是按引用传递。如果它是按引用传递的,我们应该能够像 C 中的对象交换一样,但在 java 中我们不能这样做。我们已经知道了,对吧?
Java是按值传递的
当您将对象传递给方法时,其内存地址会被逐位复制到新的引用变量,因此两者都指向同一个实例。但是,如果更改方法内部的引用,原始引用不会改变。
如果 Java 是按引用传递的,那么它也会发生变化。
为了证明这一点,让我们看看运行时内存分配是如何发生的。如果有的话,它应该可以解决最轻微的疑问。我正在使用以下程序来演示该概念。
public class Foo
{
private String attribute;
public Foo (String a){
this.attribute = a;
}
public String getAttribute() {
return attribute;
}
public void setAttribute(String attribute) {
this.attribute = attribute;
}
}
public class Main
{
public static void main(String[] args){
Foo f = new Foo("f");
changeReference(f); // 不改变引用
modifyReference(f); // 它将改变引用变量“f”所引用的对象!
}
public static void changeReference(Foo a) {
Foo b = new Foo("b");
a = b;
}
public static void modifyReference(Foo c) {
c.setAttribute("c");
}
}
分析
让我们一步步看看上面的程序运行时运行时会发生什么:
Foo f = new Foo("f");
语句将创建 Foo 类的一个实例,并将“attribute”初始化为“f”。对这个创建的实例的引用被分配给变量f;
public static void changeReference(Foo a)
当执行时,会声明一个名称为 a 的 Foo 类型的引用,并且最初将其指定为 null。
changeReference(f);
Foo b = new Foo("b"); //inside first method
这将与第一步完全相同,并将创建 Foo 的新实例,并将其分配给 b;
a = b;
这是很重要的一点。这里,我们有三个引用变量,当语句执行时,a和b将指向方法内创建的同一个实例。注意:f没有改变,它一直指向instance,它本来就是指向的。不用找了 !!
modifyReference(Foo c);
现在,当该语句执行引用时,将创建 c 并将其分配给具有属性“f”的对象。
c.setAttribute("c");
这将更改引用 c 所指向的对象的属性,以及引用 f 所指向的同一对象的属性。我希望这个解释足够清楚,能让您更好地理解(如果还没有的话)。
教程 Java基础教程
文章目录前言 第1章 Java语言基础 第2章 流程控制语句 第3章 面向对象编程 第4章 Java 字符串 […]