Java函数调用中的引用传递

本文详细探讨了Java中引用传递的两种情况:不可变对象如String的引用传递,以及可变对象引用传递的区别。通过具体代码示例,阐述了在函数调用中,不同类型的对象引用如何影响原始数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、传递的是不可变对象的引用

以String为例:

void func(String s){
    s+="asd";
    System.out.println(s);
}

String s="123";
func(s);
System.out.println(s);

 由于java中的引用传递和值传递传递的都是一个copy,即String定义的s的引用对象和func函数中的参数s是两个不同的引用,但指向同一个字符串常量。在这种情况下,func内部对s进行加操作时生成一个新的字符串常量,并且s变成新的引用,于是s输出新的字符串;而func调用下方的输出,s指向的仍是原来的引用,所以输出的字符串不变。

2、传递的是可变对象的引用

若参数是可变对象的引用,那么在函数调用中对该引用指向的数据进行修改时,函数调用结束后原对象已经被改变了。

### Java函数调用传递的工作方式 在 Java 编程语言中,所有的参数传递都是通过传递实现的。这意味着无论何时调用方法并提供参数,都会创建这些参数的一个副本,并将此副本用于方法内部的操作。 对于基本数据类型的参数而言,情况较为直观。由于整数、浮点数等基础类型的数据量较小,因此直接复制其具体的数即可完成传递过程[^1]: ```java public class ValuePassingExample { public static void changeValue(int num) { num = 99; } public static void main(String[] args) { int originalNum = 5; changeValue(originalNum); System.out.println("After method call, the value is " + originalNum); // 输出结果为5 } } ``` 当涉及到对象作为参数的情况时,虽然表面上看起来像是引用传递——因为可以在被调用方法内更改对象属性从而影响原始对象的行为;但实际上,这里依然是基于传递机制工作的。此时,“”指的是指向堆内存中某个特定位置的对象引用(即指针)。也就是说,真正发生的事情是:原对象引用所指向的位置信息被复制了一份新的引用变量来表示它,而并非整个对象结构体本身进行了转移或共享[^3]。 为了更清晰地展示这一点,可以考虑下面的例子: ```java class Person { String name; public Person(String name) { this.name = name; } } public class ReferencePassingExample { public static void changeName(Person person) { person.name = "New Name"; } public static void main(String[] args) { Person p = new Person("Old Name"); changeName(p); System.out.println("The final name of the object is: " + p.name); // 输出结果为 New Name } } ``` 在这个例子中,`changeName()` 方法接收到了 `p` 的一个副本,但这只是对同一个 `Person` 实例的不同引用而已。因此,在该方法体内所做的任何针对 `person` 变量对应对象成员字段 (`name`) 的变更都将反映回原来的实例上。然而这并不意味着这是真正的引用传递,因为在 C++ 或其他支持严格意义上的引用语义的语言里,引用一旦绑定就不能再重新赋给另一个不同的实体,而在上述代码片段中是可以让局部变量 `person` 指向一个新的 `Person` 对象而不影响外部入的那个对象的[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值