浅谈JS中的三种字符串连接方式及其性能比较


Posted in Javascript onSeptember 02, 2016

工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方法,这里将它们一一列出顺便也对它们的性能做个具体的比较。

第一种方法 用连接符“+”把要连接的字符串连起来:

str="a";
str+="b";

毫无疑问,这种方法是最便捷快速的,如果只连接100个以下的字符串建议用这种方法最方便。

第二种方法 以数组作为中介用 join 连接字符串:

var arr=new Array();
arr.push(a);
arr.push(b);
var str=arr.join("");

w3school 网站介绍说这种方法要比第一种消耗更少的资源,速度也更快,后面我们通过实验再验证是否是这样。

第三种方法 利用对象属性来连接字符串

function stringConnect(){
  this._str_=new Array();
}
stringConnect.prototype.append=function(a){
  this._str_.push(a);
}
stringConnect.prototype.toString=function(){
  return this._str_.join();
}
  var mystr=new stringConnect;
  mystr.append("a");
  var str=mystr.toString();

利用下面代码对三种方法性能进行比较,通过更改 c 的值来调整连接字符串的个数:

var str="";
var d1,d2;
var c=5000;//连接字符串的个数


//------------------------测试第三种方法耗费时间-------
 d1=new Date();
function stringConnect(){
  this._str_=new Array();
}
stringConnect.prototype.append=function(a){
  this._str_.push(a);
}
stringConnect.prototype.toString=function(){
  return this._str_.join("");
}
  var mystr=new stringConnect;

  for(var i=0;i<c;i++){
    mystr.append("a");
  }
str=mystr.toString();
 d2=new Date();
 console.log(d2.getTime()-d1.getTime());
//-----------------------------------------------------

//------------------------测试第二种方法耗费时间-------
d1=new Date();
  var arr=new Array();
for(var i=0;i<c;i++){
  arr.push("a");
}
str=arr.join("");
  d2=new Date();
console.log(d2.getTime()-d1.getTime());
//-------------------------------------------------------

//------------------------测试第一种方法耗费时间-------
d1=new Date();for(var i=0;i<c;i++){
  str+="a";
}
d2=new Date();
console.log(d2.getTime()-d1.getTime());
//-------------------------------------------------------

我调整 c 分别等于5000、50000、500000、5000000,每个数值分别测了10次,最后结果如下:

c=5000
平均耗时(单位毫秒)
第三种 3 2 2 3 1 2 2 1 1 1 1.8
第二种 1 3 0 3 1 3 4 1 4 2 2.2
第一种 0 0 0 0 0 1 1 1 1 1 0.5

c=50000

第三种 22 12 9 14 12 13 13 13 10 17 13.5
第二种 8 13 12 8 11 11 8 9 8 9 9.7
第一种 7 12 5 11 10 10 10 13 16 12 10.6

c=500000

第三种 104 70 74 69 76 77 69 102 73 73 78.7
第二种 78 100 99 99 100 98 96 71 94 97 93.2
第一种 90 87 83 85 85 83 84 83 88 86 85.4

c=5000000

第三种 651 871 465 444 1012 436 787 449 432 444 599.1
第二种 568 842 593 747 417 747 719 549 573 563 631.8
第一种 516 279 616 161 466 416 201 495 510 515 417.5

统计5000000的时候在地址栏加入了随机参数,应该是避免了缓存的影响的。从结果来看,第一种方法并不比另2种方法消耗多,甚至还更有优势,这点和手册上的说明明显不一致。

测试系统:win 7旗舰

浏览器:chrome 52.0.2739.0 m

以上这篇浅谈JS中的三种字符串连接方式及其性能比较就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript在XHTML中的用法详解
Apr 11 Javascript
将HTML格式的String转化为HTMLElement的实现方法
Aug 07 Javascript
jQuery判断checkbox是否选中的3种方法
Aug 12 Javascript
JavaScript实现同一页面内两个表单互相传值的方法
Aug 12 Javascript
判断js的Array和Object的实现方法
Aug 29 Javascript
微信小程序 获取当前地理位置和经纬度实例代码
Dec 05 Javascript
基于JS实现移动端左滑删除功能
Jul 28 Javascript
使用React手写一个对话框或模态框的方法示例
Apr 25 Javascript
3分钟读懂移动端rem使用方法(推荐)
May 06 Javascript
vue2 v-model/v-text 中使用过滤器的方法示例
May 09 Javascript
Vue scoped及deep使用方法解析
Aug 01 Javascript
JavaScript中关于预编译、作用域链和闭包的理解
Mar 31 Javascript
AngularJs  E2E Testing 详解
Sep 02 #Javascript
解决node.js安装包失败的几种方法
Sep 02 #Javascript
js两种拼接字符串的简单方法(必看)
Sep 02 #Javascript
AngularJs Understanding the Controller Component
Sep 02 #Javascript
JS 拼凑字符串的简单实例
Sep 02 #Javascript
AngularJs Understanding the Model Component
Sep 02 #Javascript
浅谈js中StringBuffer类的实现方法及使用
Sep 02 #Javascript
You might like
第4章 数据处理-php正则表达式-郑阿奇(续)
2011/07/04 PHP
PHP中比较时间大小实例
2014/08/21 PHP
PHP基于imap获取邮件实例
2014/11/11 PHP
PHP7新增运算符用法实例分析
2016/09/26 PHP
php 删除一维数组中某一个值元素的操作方法
2018/02/01 PHP
Phpstorm+Xdebug断点调试PHP的方法
2018/05/14 PHP
php多进程模拟并发事务产生的问题小结
2018/12/07 PHP
走出JavaScript初学困境—js初学
2008/12/29 Javascript
JS 显示当前日期与时间的代码
2010/03/24 Javascript
js 字符串转换成数字的三种方法
2013/03/23 Javascript
JS实现密码框根据焦点的获取与失去控制文字的消失与显示效果
2015/11/26 Javascript
AngularJS入门教程之迭代器过滤详解
2016/08/18 Javascript
工作中常用的js、jquery自定义扩展函数代码片段汇总
2016/12/22 Javascript
VUE 3D轮播图封装实现方法
2018/07/03 Javascript
仿vue-cli搭建属于自己的脚手架的方法步骤
2019/04/17 Javascript
Vue事件修饰符native、self示例详解
2019/07/09 Javascript
在Layui中操作数据表格,给指定单元格添加事件示例
2019/10/26 Javascript
JS如何在不同平台实现多语言方式
2020/07/16 Javascript
新手该如何学python怎么学好python?
2008/10/07 Python
Python编程之序列操作实例详解
2017/07/22 Python
Python实现Logger打印功能的方法详解
2017/09/01 Python
Python实现购物车功能的方法分析
2017/11/10 Python
PyQt5显示GIF图片的方法
2019/06/17 Python
Django中文件上传和文件访问微项目的方法
2020/04/27 Python
Django中ORM的基本使用教程
2020/12/22 Python
CSS3中的注音对齐属性ruby-align用法指南
2016/07/01 HTML / CSS
Html5适配iphoneX刘海屏的简单实现
2019/04/09 HTML / CSS
html5视频媒体标签video的使用方法及完整参数说明详解
2019/09/27 HTML / CSS
销售会计工作职责
2013/12/02 职场文书
护士求职自荐信范文
2014/03/19 职场文书
给公司的建议书范文
2014/05/13 职场文书
法人单位授权委托书范文
2014/10/06 职场文书
医院党建工作总结2015
2015/05/26 职场文书
2015年公司中秋节致辞
2015/07/31 职场文书
react国际化react-intl的使用
2021/05/06 Javascript
Apache POI的基本使用详解
2021/11/07 Servers