浅谈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 相关文章推荐
google 搜索框添加关键字实现代码
Apr 24 Javascript
jQuery选择没有colspan属性的td的代码
Jul 06 Javascript
6款新颖的jQuery和CSS3进度条插件推荐
Mar 05 Javascript
jQuery表格排序组件-tablesorter使用示例
May 26 Javascript
js点击按钮实现水波纹效果代码(CSS3和Canves)
Sep 15 Javascript
整理一下常见的IE错误
Nov 18 Javascript
jQuery EasyUi 验证功能实例解析
Jan 06 Javascript
echart简介_动力节点Java学院整理
Aug 11 Javascript
详解10分钟学会vue滚动行为
Sep 21 Javascript
WebPack配置vue多页面的技巧
May 15 Javascript
JS+H5 Canvas实现时钟效果
Jul 20 Javascript
JavaScript实现PC端横向轮播图
Feb 07 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 at(@)符号的用法简介
2009/07/11 PHP
php环境下利用session防止页面重复刷新的具体实现
2014/01/09 PHP
微信营销平台系统?刮刮乐的开发
2014/06/10 PHP
PHP合并数组的2种方法小结
2016/11/24 PHP
ajax 文件上传应用简单实现
2009/03/03 Javascript
juqery 学习之六 CSS--css、位置、宽高
2011/02/11 Javascript
js中escape对应的C#解码函数 UrlDecode
2012/12/16 Javascript
jQuery实现页面顶部显示的进度条效果完整实例
2015/12/09 Javascript
javascript实现2016新年版日历
2016/01/25 Javascript
原生js更改css样式的两种方式
2017/03/15 Javascript
vue中页面跳转拦截器的实现方法
2017/08/23 Javascript
捕获未处理的Promise错误方法
2017/10/13 Javascript
vue微信分享 vue实现当前页面分享其他页面
2017/12/02 Javascript
layui结合form,table的全选、反选v1.0示例讲解
2018/08/15 Javascript
对vuejs的v-for遍历、v-bind动态改变值、v-if进行判断的实例讲解
2018/08/27 Javascript
H5+C3+JS实现五子棋游戏(AI篇)
2020/05/28 Javascript
elementUI 设置input的只读或禁用的方法
2018/10/30 Javascript
bootstrap与pagehelper实现分页效果
2018/12/29 Javascript
JavaScript定时器设置、使用与倒计时案例详解
2019/07/08 Javascript
python实现得到一个给定类的虚函数
2014/09/28 Python
使用Python编写爬虫的基本模块及框架使用指南
2016/01/20 Python
Python实现两款计算器功能示例
2017/12/19 Python
详解python使用Nginx和uWSGI来运行Python应用
2018/01/09 Python
Python使用pyh生成HTML文档的方法示例
2018/03/10 Python
将字典转换为DataFrame并进行频次统计的方法
2018/04/08 Python
Python 字节流,字符串,十六进制相互转换实例(binascii,bytes)
2020/05/11 Python
互动出版网:专业书籍
2017/03/21 全球购物
Ashford台湾:以折扣价提供奢华的男女用表款
2019/12/04 全球购物
秘书行业自我鉴定范文
2013/12/30 职场文书
经理助理岗位职责
2014/03/05 职场文书
社会稳定风险评估方案
2014/06/02 职场文书
检察机关个人对照检查材料
2014/09/15 职场文书
个人原因辞职信模板
2015/05/13 职场文书
单位接收证明格式
2015/06/18 职场文书
2019年教师节祝福语精选,给老师送上真诚的祝福
2019/09/09 职场文书
2019年世界儿童日宣传标语
2019/11/22 职场文书