浅谈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 无提示关闭窗口脚本
Aug 17 Javascript
分享有关jQuery中animate、slide、fade等动画的连续触发、滞后反复执行的bug
Jan 10 Javascript
Node.js开发者必须了解的4个JS要点
Feb 21 Javascript
一个超简单的jQuery回调函数例子(分享)
Aug 08 Javascript
js实现扫雷小程序的示例代码
Sep 27 Javascript
深入理解React高阶组件
Sep 28 Javascript
jquery的 filter()方法使用教程
Mar 22 jQuery
如何用input标签和jquery实现多图片的上传和回显功能
May 16 jQuery
vue 设置 input 为不可以编辑的实现方法
Sep 19 Javascript
微信小程序如何实现在线客服功能
Oct 16 Javascript
Vue根据条件添加click事件的方式
Nov 09 Javascript
微信小程序实现音频文件播放进度的实例代码
Mar 02 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
PHP使用缓存即时输出内容(output buffering)的方法
2015/08/03 PHP
用JavaScript调用WebService的示例
2008/04/07 Javascript
Javascript Math对象
2009/08/13 Javascript
js 强制弹出窗口代码研究-又一款代码
2010/03/20 Javascript
jQuery的实现原理的模拟代码 -3 事件处理
2010/08/03 Javascript
基于jquery tab切换(防止页面刷新)
2012/05/23 Javascript
使用script的src实现跨域和类似ajax效果
2014/11/10 Javascript
jQuery将所有被选中的checkbox某个属性值连接成字符串的方法
2015/01/24 Javascript
jQuery插件pagination实现分页特效
2015/04/12 Javascript
node模块机制与异步处理详解
2016/03/13 Javascript
jQuery on()方法绑定动态元素的点击事件实例代码浅析
2016/06/16 Javascript
JS实现图片局部放大或缩小的方法
2016/08/20 Javascript
Web打印解决方案之证件套打的实现思路
2016/08/29 Javascript
Javascript 判断两个IP是否在同一网段实例代码
2016/11/28 Javascript
jQuery控制元素隐藏和显示
2017/03/03 Javascript
Nodejs进阶:express+session实现简易登录身份认证
2017/04/24 NodeJs
Angular 2.x学习教程之结构指令详解
2017/05/25 Javascript
p5.js入门教程之平滑过渡(Easing)
2018/03/16 Javascript
详细教你微信公众号正文页SVG交互开发技巧
2019/07/25 Javascript
[01:32]DOTA2上海特锦赛现场采访:最想COS的英雄
2016/03/25 DOTA
python数据结构之图深度优先和广度优先实例详解
2015/07/08 Python
各种Python库安装包下载地址与安装过程详细介绍(Windows版)
2016/11/02 Python
Python pygorithm模块用法示例【常见算法测试】
2018/08/16 Python
Python学习笔记之pandas索引列、过滤、分组、求和功能示例
2019/06/03 Python
Python动态语言与鸭子类型详解
2019/07/01 Python
手把手教你从PyCharm安装到激活(最新激活码),亲测有效可激活至2089年
2020/11/25 Python
详解Python爬虫爬取博客园问题列表所有的问题
2021/01/18 Python
台湾良兴购物网:EcLife
2019/12/01 全球购物
大学军训自我鉴定
2013/12/15 职场文书
优秀员工获奖感言
2014/03/01 职场文书
语文高效课堂实施方案
2014/05/03 职场文书
银行党的群众路线教育实践活动对照检查材料
2014/09/25 职场文书
考教师资格证不要错过的4个最佳时机
2019/07/17 职场文书
创业计划书之花店
2019/09/20 职场文书
python turtle绘图命令及案例
2021/11/23 Python
Python测试框架pytest高阶用法全面详解
2022/06/01 Python