我来水个 Java 字符串拼接的问题

本贴最后更新于 2034 天前,其中的信息可能已经东海扬尘

Java 字符串拼接是直接这样:

String b = "123";
String d = "a" + b + "c" + ...;

还是调用像这样的方法,好一些:

public static String append(Object... strings) {
    if (strings.length == 0) {
        return "";
    }

    StringBuilder builder = new StringBuilder(Arrays.toString(strings).length);
    for (String str : strings) {
	builder.append(str);
    }

    return builder.toString();
}

理由是...

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3190 引用 • 8214 回帖
  • 字符串
    30 引用 • 57 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    8627 引用 • 39374 回帖 • 145 关注

相关帖子

被采纳的回答
  • 88250 1 1 赞同

    前者简单些好。虽然提炼小方法可以提升代码可读性,但大部分场景下并不需要这样做。或者说即使非要这样做,可以考虑放在后期重构优化阶段,项目开始时不用做到这么细致,除非这部分代码是核心代码。

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • someone9891 1 2 赞同
    String b = "123"; 
    String d = "a" + b + "c" + ...;
    

    这个其实是不影响的。只有

    String a = "2";
    String b = "2121"
    String c = a+ b; 
    

    的时候才会出现多个对象的问题。

  • someone9891 1 1 赞同

    还有就是,你这段代码编译通不过

    public static String append(Object... strings) {
            if (strings.length == 0) {
                return "";
            }
            StringBuilder builder = new StringBuilder(strings.length);
            for (Object str : strings) {
                builder.append(str);
            }
    
            return builder.toString();
        }
    

    Arrays.toString() 返回的是一个 String,String 没有 length 属性,但是有个 length()方法,

    但是根据你需要的 String 拼接的话,你完全就把参数的 strings 遍历 append 到 builder 就可以了

    1 回复
  • someone9891 1 1 赞同

    至于你说的,理由,是因为 builder 只有一个对象,而 String + 的时候,可能会产生多个对象。
    比如:

    String a = "1";
    for(int i =0; i < 10 ;i ++){
    	String b += a;
    }
    
    

    这样其实产生了很多个对象。

    但是

    String a = "22";
    StringBuilder bd = new StringBuilder();
    for(int i =0 ;i< 10 ;i++){
    	bd.append(a);
    }
    

    这样其实就两个对象。
    另外提一句,多线程情况,请考虑用 StringBuffer ,StringBuffer 的 append 方法 是同步的,如下为 jdk1.8 源码:

        @Override
        public synchronized StringBuffer append(Object obj) {
            toStringCache = null;
            super.append(String.valueOf(obj));
            return this;
        }
    
        @Override
        public synchronized StringBuffer append(String str) {
            toStringCache = null;
            super.append(str);
            return this;
        }
    
  • 88250 1 1 赞同

    前者简单些好。虽然提炼小方法可以提升代码可读性,但大部分场景下并不需要这样做。或者说即使非要这样做,可以考虑放在后期重构优化阶段,项目开始时不用做到这么细致,除非这部分代码是核心代码。

    2 回复
  • Eddie

    结果编译器优化掉了。一样没差trollface

  • ellenbboe

    Stringbuffer 是线程安全的,前面通过简单的 + 不是线程安全

    2 回复
    1 操作
    ellenbboe 在 2019-06-16 13:50:30 更新了该回帖
  • ellenbboe

    之前似乎看过 单线程少量数据的用 + 就好了 多线程的用 stringbuffer 单线程大量数据用 builder

    1 操作
    ellenbboe 在 2019-06-15 12:01:36 更新了该回帖
  • Keith1024

    Stringbuilder 不是线程安全的

    1 回复
  • iTanken

    实不相瞒...我这两段代码是纯手打的,不是复制过来的,忘了加 length 方法的括号了 trollface

  • iTanken 1

    有道理。“过早的优化是万恶之源” huaji

  • ellenbboe

    ...错了.是 buffer(尴尬)

  • StringBuilder 也不是线程安全的,只是会比 某些情况下直接 + 创建更少的对象,StringBuffer 才是线程安全的,原因可以看我之前的回复,因为 append 方法是同步的

  • dragon8869

    非核心代码的话,没多大关系的吧

  • hugqq 1

    StringJoiner

    1 回复
  • iTanken

    感谢,通过 StringJoiner,了解到了 String.join(),这正是我想要的,就像 JS 的 Array.join() 一样方便。

请输入回帖内容 ...
iTanken
飘风不终朝,骤雨不终日。 重庆

推荐标签 标签

  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖 • 1 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    288 引用 • 735 回帖 • 1 关注
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 655 关注
  • 招聘

    哪里都缺人,哪里都不缺人。

    190 引用 • 1057 回帖
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 4 关注
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    107 引用 • 127 回帖 • 367 关注
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖 • 2 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    210 引用 • 2036 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    8627 引用 • 39374 回帖 • 145 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    159 引用 • 3804 回帖 • 1 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 491 关注
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1706 回帖 • 1 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 24 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 647 关注
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖 • 2 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    166 引用 • 595 回帖
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 689 关注
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 564 关注
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 677 关注
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 147 关注
  • 安全

    安全永远都不是一个小问题。

    201 引用 • 816 回帖
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 773 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 75 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    408 引用 • 3575 回帖