Java字符串操作进阶:StringBuilder与StringBuffer剖析

文章标题:

Java字符串操作深度解析:StringBuilder与StringBuffer详解

文章内容

文章目录

  • 字符串的不可变性
  • StringBuilder与StringBuffer
    • 函数运用

字符串的不可变性

字符串之所以不可变,是因为其内部采用了private修饰,仅能在类的内部被访问,外部无法直接对其进行修改。例如下面的代码:

public class test {
    public static void main(String[] args) {
        String str = "abc";
        str += "def";
        System.out.println(str);
    }
}

StringBuilder与StringBuffer

基础示例

public class test {
    public static void main1(String[] args) {
        String str = "abc";
        str += "def";
        System.out.println(str);
    }

    public static void main(String[] args) {
        String str = "hello";
        StringBuilder stringBuilder = new StringBuilder();
        stringBuilder.append(str);
        stringBuilder.append("abc");
        str = stringBuilder.toString();
        System.out.println(str);
    }
}

性能差异剖析

  1. 速度对比:通常情况下,StringBuilder的执行速度要明显快于String。这是因为String每次进行拼接操作时都会创建新的String对象,而使用StringBuilder进行append操作后再转为String,避免了频繁的对象创建与销毁,减少了性能消耗。
  2. 对象生成情况:每次String进行拼接都会产生新的对象,而StringBuilder和StringBuffer在拼接过程中不会生成新的对象,直接在原对象基础上进行操作。

性能测试代码示例

public class Test {
    public static void main(String[] args) {
        // 记录String操作的起始时间
        long start = System.currentTimeMillis();
        String s = "";
        for (int i = 0; i < 10000; i++) {
            s += i;
        }
        // 记录String操作的结束时间并计算耗时
        long end = System.currentTimeMillis();
        System.out.println("String的时间:" + (end - start));

        // 记录StringBuilder操作的起始时间
        long start1 = System.currentTimeMillis();
        StringBuilder stringBuilder = new StringBuilder("");
        for (int i = 0; i < 10000; i++) {
            stringBuilder.append(i); // 执行拼接操作
        }
        // 记录StringBuilder操作的结束时间并计算耗时
        long end1 = System.currentTimeMillis();
        System.out.println("StringBuilder的时间:" + (end1 - start1));

        // 记录StringBuffer操作的起始时间
        long start2 = System.currentTimeMillis();
        StringBuffer stringBuffer = new StringBuffer("");
        for (int i = 0; i < 10000; i++) {
            stringBuffer.append(i);
        }
        // 记录StringBuffer操作的结束时间并计算耗时
        long end2 = System.currentTimeMillis();
        System.out.println("StringBuffer的时间:" + (end2 - start2));
    }
}

线程安全性区别

  1. StringBuffer的线程安全性:StringBuffer是线程安全的,其所有方法都使用synchronized修饰,这意味着同一时间只能有一个线程执行其方法,通过锁机制保证线程安全,但锁的获取与释放会带来一定的性能开销,所以StringBuffer比StringBuilder慢。
  2. 线程安全的含义:线程安全指的是同一时间仅有一个线程能够执行相关操作,执行完成后会释放锁。但锁的获取与释放过程会消耗时间,因此StringBuffer在性能上不如StringBuilder。

函数使用

特殊方法

  1. reverse方法:可对字符串进行逆置操作。例如:
public static void main(String[] args) {
    StringBuilder stringBuilder = new StringBuilder("hello");
    stringBuilder.reverse();
    System.out.println(stringBuilder);
}

三者区别总结

  • String的内容不可修改,每次拼接都会生成新的对象。
  • StringBuilder和StringBuffer的内容可以修改,直接在原对象上进行操作。
  • StringBuilder未采用同步处理,是线程不安全的;StringBuffer采用了同步处理,是线程安全的。它们的函数有相似之处。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12721.html

(0)
LomuLomu
上一篇 2025 年 7 月 3 日
下一篇 2025 年 7 月 3 日

相关推荐

  • 全网通用clion激活码获取方式与权威clion破解教程

    声明:本教程中涉及的 Clion 破解补丁与激活码均来自互联网公开渠道,仅供个人学习研究,禁止商业用途。若出现侵权,请立即联系作者删除。条件允许时,请支持正版! 废话少说,先上图:Clion 2025.2.1 已成功激活至 2099 年,爽! 下面用图文一步步演示如何给最新版 Clion 打上补丁。 前期准备 如果你之前试过别的破解补丁没成功,建议先卸载干净…

    2025 年 11 月 29 日
    22400
  • 无需邀请码免费申领datagrip激活码,实用破解教程

    声明:本文所涉及的 DataGrip 破解补丁与激活码均源自网络公开资源,仅供个人学习研究,禁止商用。若条件允许,请支持正版! 先放一张“战绩图”——DataGrip 2025.2.1 已成功激活到 2099 年,爽翻! 下面用图文手把手带你完成最新版 DataGrip 的激活流程。 嫌折腾?直接入手官方正版,全家桶账号低至 32 元/年,登录即用:http…

    DataGrip激活码 2025 年 10 月 22 日
    30100
  • 2024 IDEA最新激活码,IDEA永久免费激活码2025-01-21 更新

    IDEA 2024最新激活码 以下是最新的IDEA激活码,更新时间:2025-01-21 🔑 激活码使用说明 1️⃣ 复制下方激活码 2️⃣ 打开 IDEA 软件 3️⃣ 在菜单栏中选择 Help -> Register 4️⃣ 选择 Activation Code 5️⃣ 粘贴激活码,点击 Activate ⚠️ 必看!必看! 🔥 获取最新激活码: 实时更…

    2025 年 1 月 21 日
    89700
  • ChatGPT Plus订阅还是Pro订阅?续费前先复盘过去30天,通常就知道该不该升级

    ChatGPT Plus订阅和ChatGPT Pro订阅到底怎么选,很多人会在续费当天才开始犹豫,其实这时最容易被情绪带着走。更实用的办法,是先复盘过去 30 天你到底把 AI 用在了哪些事情上,再决定继续用 Plus,还是有必要上更高档位。 如果你近期正准备开通或续费,我更建议优先选一个自己已经反复用过、支付路径也更省心的平台,省得在赶任务的时候还要分神处…

    ChatGPT 2026 年 4 月 16 日
    13200
  • 【Java】还在死磕算法?懂“堆”与“优先级队列”,代码效率飙升

    欢迎 💛点赞 🌟收藏 💫关注 🏆堆 一、🎯堆的定义 堆的概念 堆是一种特殊的完全二叉树,它通过一维数组顺序存储关键码集合K={k0,k1,k2,…,kn-1},并遵循特定的顺序关系来定义。具体来说,若对于任意节点Ki,都满足Ki = 0; parent–) { siftDown(parent, usedSize); } } public void si…

    2024 年 12 月 27 日
    55000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信