浅谈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 相关文章推荐
子窗体与父窗体传值示例js代码
Aug 01 Javascript
鼠标滑在标题上显示图片的JS代码
Nov 19 Javascript
javascript中数组中求最大值示例代码
Dec 18 Javascript
基于jquery实现图片相关操作(重绘、获取尺寸、调整大小、缩放)
Dec 25 Javascript
javacript获取当前屏幕大小
Jun 04 Javascript
Angular 4依赖注入学习教程之ValueProvider的使用(七)
Jun 04 Javascript
anime.js 实现带有描边动画效果的复选框(推荐)
Dec 24 Javascript
AngularJS实现动态切换样式的方法分析
Jun 26 Javascript
详解如何使用nvm管理Node.js多版本
May 06 Javascript
vue pages 多入口项目 + chainWebpack 全局引用缩写说明
Sep 21 Javascript
在Vue中使用Viser说明(基于AntV-G2可视化引擎)
Oct 28 Javascript
React中的Context应用场景分析
Jun 11 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生成数组再传给js的方法
2014/08/07 PHP
完美解决thinkphp验证码出错无法显示的方法
2014/12/09 PHP
php 猴子摘桃的算法
2017/06/20 PHP
PHP+MariaDB数据库操作基本技巧备忘总结
2018/05/21 PHP
详解PHP素材图片上传、下载功能
2019/04/12 PHP
phpQuery采集网页实现代码实例
2020/04/02 PHP
YII2框架中日志的配置与使用方法实例分析
2020/03/18 PHP
json的定义、标准格式及json字符串检验
2014/05/11 Javascript
探寻Javascript执行效率问题
2014/11/12 Javascript
JavaScript中的函数模式详解
2015/02/11 Javascript
JavaScript 事件入门知识
2015/04/13 Javascript
JavaScript iframe数据共享接口实现方法
2016/01/06 Javascript
vue.js移动端app实战1:初始配置详解
2017/07/24 Javascript
微信小程序 转发功能的实现
2017/08/04 Javascript
js实现1,2,3,5数字按照概率生成
2017/09/12 Javascript
vue自定义移动端touch事件之点击、滑动、长按事件
2018/07/10 Javascript
webpack是如何实现模块化加载的方法
2019/11/06 Javascript
jQuery实现小火箭返回顶部特效
2020/02/03 jQuery
vue实现虚拟列表功能的代码
2020/07/28 Javascript
vue项目中播放rtmp视频文件流的方法
2020/09/17 Javascript
JavaScript中遍历的十种方法总结
2020/12/15 Javascript
[02:43]DOTA2英雄基础教程 半人马战行者
2014/01/13 DOTA
Python ldap实现登录实例代码
2016/09/30 Python
Python的CGIHTTPServer交互实现详解
2018/02/08 Python
图解Python变量与赋值
2018/04/03 Python
python购物车程序简单代码
2018/04/18 Python
对python中大文件的导入与导出方法详解
2018/12/28 Python
劳动模范事迹材料
2014/01/19 职场文书
新书吧创业计划书
2014/01/31 职场文书
2014年会策划方案
2014/05/11 职场文书
法制演讲稿
2014/09/10 职场文书
2014年维修工作总结
2014/11/22 职场文书
红楼梦读书笔记
2015/06/25 职场文书
获奖感言怎么写
2015/07/31 职场文书
2019西餐厅创业计划书范文!
2019/07/12 职场文书
一小时学会TensorFlow2之基本操作2实例代码
2021/09/04 Python