浅谈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 相关文章推荐
几行代码轻松搞定jquery实现flash8类似的连接效果
May 03 Javascript
什么是JavaScript
Aug 13 Javascript
用js小类库获取浏览器的高度和宽度信息
Jan 15 Javascript
jquery用ajax方式从后台获取json数据后如何将内容填充到下拉列表
Aug 26 Javascript
js实现简单排列组合的方法
Jan 27 Javascript
Bootstrap每天必学之导航组件
Apr 25 Javascript
Bootstrap轮播图的使用和理解4
Dec 14 Javascript
原生js实现图片放大缩小计时器效果
Jan 20 Javascript
js oncontextmenu事件使用详解
Mar 25 Javascript
JS实现图片点击后出现模态框效果
May 03 Javascript
jQuery开源组件BootstrapValidator使用详解
Jun 29 jQuery
Vue2.0 http请求以及loading展示实例
Mar 06 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
输出控制类
2006/10/09 PHP
php生成缩略图示例代码分享(使用gd库实现)
2014/01/20 PHP
Ubuntu中搭建Nginx、PHP环境最简单的方法
2015/03/05 PHP
PHP使用ffmpeg给视频增加字幕显示的方法
2015/03/12 PHP
Zend Studio使用技巧两则
2016/04/01 PHP
PHP从零开始打造自己的MVC框架之类的自动加载实现方法详解
2019/06/03 PHP
javascipt基础内容--需要注意的细节
2013/04/10 Javascript
原始XMLHttpRequest方法详情回顾
2013/11/28 Javascript
JS实现带有抽屉效果的产品类网站多级导航菜单代码
2015/09/15 Javascript
jquery动态切换背景图片的简单实现方法
2016/05/14 Javascript
微信小程序 scroll-view实现上拉加载与下拉刷新的实例
2017/01/21 Javascript
vue loadmore组件上拉加载更多功能示例代码
2017/07/19 Javascript
vuex 使用文档小结篇
2018/01/11 Javascript
vue路由拦截及页面跳转的设置方法
2018/05/24 Javascript
JavaScript如何实现图片处理与合成
2020/05/29 Javascript
[04:09]2014DOTA2国际邀请赛Ti西雅图 历届冠军相继出局 BBC综述今日比赛
2014/07/20 DOTA
基于python实现的百度新歌榜、热歌榜下载器(附代码)
2019/08/05 Python
django-rest-swagger的优化使用方法
2019/08/29 Python
Django 框架模型操作入门教程
2019/11/05 Python
Python3将ipa包中的文件按大小排序
2020/04/17 Python
Python使用re模块验证危险字符
2020/05/21 Python
python中有帮助函数吗
2020/06/19 Python
python的数学算法函数及公式用法
2020/11/18 Python
Elemis美国官网:英国的第一豪华护肤品牌
2018/03/15 全球购物
澳大利亚工具仓库:Tools Warehouse
2018/10/15 全球购物
碧欧泉法国官网:Biotherm法国
2019/10/23 全球购物
小学教师学期末自我评价
2013/09/25 职场文书
竞聘上岗演讲稿范文
2014/01/10 职场文书
运动会闭幕式解说词
2014/02/21 职场文书
党的群众路线教育实践活动总结
2014/10/30 职场文书
2014年幼师工作总结
2014/11/22 职场文书
如何使用JavaScript策略模式校验表单
2021/04/29 Javascript
Pycharm 如何设置HTML文件自动补全代码或标签
2021/05/21 Python
Python 内置函数速查表一览
2021/06/02 Python
为什么MySQL不建议使用SELECT *
2022/04/03 MySQL
win10如何快速切换窗口 win10切换窗口快捷键分享
2022/07/23 数码科技