Java引用传递

引用传递的实质就是不同栈内存空间可以指向同一块堆内存空间,并对其内容进行修改,以下通过3个代码案例详细介绍

案例一

class Message{
    private int anInt = 10;
    public Message(int anInt){
        this.anInt = anInt;
    }

    public void setAnInt(int anInt) {
        this.anInt = anInt;
    }

    public int getAnInt() {
        return anInt;
    }
}
public class ReferenceDemo {
    public static void main(String[] args){
        Message message = new Message(30);
        fun(message);
        System.out.println(message.getAnInt());
        }
    public static void fun(Message temp){
        temp.setAnInt(100);
    }
}

这里需要注意的就是对于程序的执行过程都是从右向左执行,对于内存进行简单的分析可以知道,

案例二

public class ReferenceDemo {
    public static void main(String[] args){
        String string = "hello";
        fun(string);
        System.out.println(string);
    }

    public static void fun(String temp){
        temp = "world";
    }
}
输出:
hello

案例三

class Message{
    private String strInfo = "Hello";
    public Message(String strInfo){
        this.strInfo = strInfo;
    }

    public void setStrInfo(String strInfo) {
        this.strInfo = strInfo;
    }

    public String getStrInfo() {
        return strInfo;
    }

}
public class ReferenceDemo {
    public static void main(String[] args){
        Message message = new Message("NiHao");
        fun(message);
        System.out.println(message.getStrInfo());
    }

    public static void fun(Message temp){
        temp.setStrInfo("World");
    }
}
输出:
World
### Java引用传递的工作原理 Java 的方法调用机制严格遵循 **值传递** 的原则。即使对于对象类型的变量,在方法调用时也是通过复制其引用地址的值来实现参数传递[^1]。 当一个对象作为参数被传入方法时,实际上传递的是该对象引用的一个副本。这个副本指向堆内存中同一个对象实例。因此,在方法内部可以修改对象的状态(即改变对象的内容),因为这些操作作用于原始的对象实例上。然而,如果尝试重新赋值给方法内的局部引用变量,则不会影响到外部的实际引用变量,因为它只是改变了本地副本所指的位置[^2]。 #### 示例代码解析 以下是一个典型的例子用于展示这一行为: ```java public class ArrayListDemo { public static void main(String[] args) { Person person = new Person("zhangsan"); System.out.println(person.getName()); // 输出 zhangsan changePerson(person); System.out.println(person.getName()); // 输出仍是 zhangsan, 因为仅更改了副本引用 } public static void changePerson(Person p) { Person temp = new Person("lisi"); p = temp; } } ``` 在这个案例里,`changePerson()` 方法接收了一个 `Person` 对象的引用拷贝。尽管我们在函数体内创建了一个新的 `Person` 实例并将其赋予 `p`,这仅仅更新了方法范围内的局部变量 `p` 所指向的对象,并未对外部的 `person` 引用造成任何影响[^3]。 但是需要注意的是,假如我们不是重设整个引用而是修改原对象属性的话,那么这种变化是可以反映回原来的对象上的。这是因为两个引用共享同一份底层的数据结构。 ### 总结 综上所述,虽然表面上看起来像是“引用传递”,但实际上由于每次都是传送引用本身的值而非直接操纵源引用本身,所以本质上仍然是基于值的传输方式。只有当涉及具体成员字段的操作才会真正体现出来自不同地方却共同指向单一实体的结果差异.
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值