Java字符串拼接选择

一般我们拼接字符串的方式有三种:

  • 加号

  • concat方法

  • StringBuilder的append()方法

 //加号 str += "xiaobear"     //concat方法 str = str.concat("xiaobear")

测试性能

分别对上面三种方式循环5w次​​​​​​​

public class StringTest {      public static void main(String[] args) {         doWithAdd();         doWithConcat();         doWithStringBuilder();    }      public static void doWithAdd(){         StopWatch stopWatch = new StopWatch();         String s = null;         stopWatch.start("add");         for (int i = 0; i < 50000; i++) {             s += "xiaobear";        }         stopWatch.stop();         System.out.println("add耗时:" + (stopWatch.getTotalTimeMillis()) + "ms");    }      public static void doWithConcat(){         StopWatch stopWatch = new StopWatch();         String s = "1";         stopWatch.start("concat");         for (int i = 0; i < 50000; i++) {             s = s.concat("xiaobear") ;        }         stopWatch.stop();         System.out.println("concat耗时:" + (stopWatch.getTotalTimeMillis()) + "ms");    }      public static void doWithStringBuilder(){         StopWatch stopWatch = new StopWatch();         StringBuilder s = new StringBuilder("1");         stopWatch.start("StringBuilder");         for (int i = 0; i < 50000; i++) {             s.append("xiaobear");        }         stopWatch.stop();         System.out.println("StringBuilder耗时:" + (stopWatch.getTotalTimeMillis()) + "ms");    }  }
add耗时:7320msconcat耗时:2001msStringBuilder耗时:1ms

加号的执行时间为7320ms,concat方法的执行时间为2001ms,而StringBuilder几乎接近0,时间非常短;

说明在拼接字符串上,append()方法最快,concat 方法次之,加号最慢;

“+” 方法拼接字符串

虽然编译器对子­符串的加号做了优化,它会使用StringBuilderd的append方法进行追加,按道理来说, 其执行时间也应该是 0 毫秒,最终是通过toString()转换为字符串的

示例中的“+”拼接的代码与如下代码相同

 str += "xiaobear"  str = new StringBuilder(str).append("xiaobear").toString();

它与StringBuilder的append()是不同的:

  • 每次循环都会创建一个StringBuilder对象

  • 拼接完成后,会调用toString()转换为字符串

所以耗时就消耗在这里了

concat方法拼接字符串

 //源码 public String concat(String str) {     //如果拼接的字符串为0,则返回字符串本身     if (str.isEmpty()) {         return this;    }     //获取原字符数组的长度     int len = value.length;     //获取拼接字符串的长度     int otherLen = str.length();     //数组拷贝     char buf[] = Arrays.copyOf(value, len + otherLen);     //拼接字符串转化为字符数组,添加到buf     str.getChars(buf, len);     //返回一个新的字符串     return new String(buf, true); }

整体看上去是一个数组拷贝,内存中处理的也是原子操作,速度很快,但是最后返回的,都会创建一个新的String对象,循环5w次,就创建了5w个String对象

append方法拼接字符串

public AbstractStringBuilder append(String str) {     //拼接字符串为空,返回空字符串     if (str == null)         return appendNull();     //获取字符串长度     int len = str.length();     //加长,并进行数组拷贝     ensureCapacityInternal(count + len);     //字符串复制到目标数组     str.getChars(0, len, value, count);     //count长度增加     count += len;     return this; }

append()方法都在做字符串数组处理,加长,数组拷贝,没有新建任何对象,所以速度是最快的!

三者的实现不同,性能也就不同,并不是我们一定要使用StringBuilder,对于简单的拼接,“+”号更能简化代码,符合我们日常的使用习惯,阅读性也好一点;

在性能层面上,才去考虑使用concat()方法或append()方法;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小熊学Java

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值