对String、StringBuilder和StringBuffer的探索

本文通过实例对比String、StringBuilder和StringBuffer在Java中的行为差异,深入解析了它们的内部实现机制,揭示了为何String在方法调用后不变,而StringBuilder和StringBuffer可以修改原对象的原因。

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

 

目录

1.从实例开始


1.从实例开始

先阅读以下代码,并将自己的运行结果记在心中,接着看程序运行结果,看看是否真实结果相同?

public class MyStrBox {
    public static void Method1(String str){
        str += "Method1()";
        System.out.println("Method1方法体中:" + str);
    }

    public static void Method2(StringBuilder strBd){
        strBd.append("Method2()");
        System.out.println("Method2方法体中:" + strBd);
    }

    public static void Method3(StringBuffer strBf){
        strBf.append("Method3()");
        System.out.println("Method3方法体中:" + strBf);
    }

    public static void main(String[] args) {

        String str = new String("I'm studying java:");
        System.out.println("原字符串:" + str);
        Method1(str);
        System.out.println("新字符串:" + str);
        System.out.println();

        StringBuilder strBd = new StringBuilder("I'm studying java:");
        System.out.println("原字符串:" + strBd);
        Method2(strBd);
        System.out.println("新字符串:" + strBd);
        System.out.println();

        StringBuffer strBf = new StringBuffer("I'm studying java:");
        System.out.println("原字符串:"+ strBf);
        Method3(strBf);
        System.out.println("新字符串:" + strBf);
        System.out.println();
    }

上面代码的运行结果为:

此段代码的运行结果可能和预想的结果不同,为什么会出现这种情况?下面我们就一起一探究竟。

2.String、StringBuilder和StringBuffer解析

2.1String类

为何在main()方法中打印Method1()处理后“I'm studying java:”,字符串依然没有改变?那就要从String类的源码说起。

首先看一下String类的源码的部分截图:

截图1:

截图2:

 截图3:

从String类的源码可以看出:第一、String类被final修饰,即String类不可以被继承。第二、String类的成员方法concat()、replace()、substring()等方法再处理完字符串后都是返回一个新的String对象。原对象在经过处理后不会发生改变,所以才会出现截图中的处理结果。

2.2StringBuilder与StringBuffer类

这两个类的实例对象每次使用append()方法追加字符串都是对同一对象进行的操作,所以才会出现Method2()和Method3()处理后,字符串“I'm studying java:”发生改变。

StringStringBuilderStringBuffer是Java中用于处理字符串的三种类。 String是不可变的,也就是说一旦创建就不能被修改。每次对String进行操作(如拼接、替换)都会生成一个新的String对象,原始的String对象则会被丢弃。这使得在频繁操作字符串的情况下,会产生大量的临时对象,造成内存浪费。因此,当字符串不需要频繁修改时,可以使用String来提高性能。 StringBuilderStringBuffer是可变的字符串类,它们可以进行修改操作而不会创建新的对象。两者的主要区别在于线程安全性性能上的差异。 StringBuffer是线程安全的,所有的方法都使用synchronized关键字进行同步,保证了多线程环境下的安全性。然而,这也导致了性能上的损失,因为同一时间只能有一个线程访问StringBuffer对象。 StringBuilder是非线程安全的,它的方法没有使用synchronized关键字进行同步。这使得在单线程环境下,StringBuilder的性能比StringBuffer更好。因此,如果在单线程环境下进行字符串操作,建议使用StringBuilder。 如果需要将StringBufferStringBuilder对象转换为String对象,有两种方法可以实现。一种是通过调用toString()方法,将其转换为String对象。另一种是通过String的构造器String(StringBuffer buffer)来创建一个新的String对象,该构造器会将StringBuffer的内容复制到新的String对象中。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [StringStringBufferStringBuilder类详解](https://blog.youkuaiyun.com/weixin_38568503/article/details/113794751)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值