StringBuffer 传值的小问题

本文通过具体的Java代码示例,深入探讨了对象在方法间传递时的行为特性,特别是StringBuffer对象的引用传递与修改机制,揭示了在方法内修改对象对外部调用者的影响。

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

下面是一个小例子: 

public static  void main(String []args) {
    StringBuffer str1 = new StringBuffer("good");
    StringBuffer str2 = new StringBuffer("bad");
    test (str1, str2);
    System.out.println(str1.toString());
    System.out.println(str2.toString());
}

public static void test (StringBuffer str1,StringBuffer str2) {
    str1 = str2;
    str1 = new StringBuffer("world");
    str2.append(" test");
}

关于对象输出的一个问题,大家猜猜输出内容是什么。

输出结果:

str1=good
str2=bad test

答案是str1=good 因为在main方法中已经创建一个StringBuffer 在堆地址中已经存在,在test种方法在进行创建是不会替换main方法中str1中的对象,str2=bad test 是因为对象进行追加所以等于bad test。

如果不理解可以看下面的例子

 public static  void main(String []args) {
        StringBuffer str1 = new StringBuffer("good");
        StringBuffer str2 = new StringBuffer("bad");
        test (str1, str2);
        System.out.println(str1.toString());
        System.out.println(str2.toString());
    }

    public static void test (StringBuffer str1,StringBuffer str2) {
        str1 = str2;
        str1 = new StringBuffer("world");
        str2.append(" test");
        System.out.println("test方法");
        System.out.println(str1.toString());
    }

输出结果: 

test方法
world
good
bad test

在test 方法中str1的输出,我们发现是改变str1的对象啦,在对比main方法中str1可以得出答案,在一个方法中新建对象,只在这个方法是有效的,不会影响其他方法的值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值