浅谈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 时间间隔计算的函数(间隔天数)
Nov 15 Javascript
jquery 操作DOM的基本用法分享
Apr 05 Javascript
Jquery AJAX POST与GET之间的区别
Nov 14 Javascript
基于jQuery实现仿淘宝套餐选择插件
Mar 04 Javascript
Express的路由详解
Dec 10 Javascript
jQuery siblings()用法实例详解
Apr 26 Javascript
Javascript之BOM(window对象)详解
May 25 Javascript
jQuery页面加载初始化的3种方法(推荐)
Jun 02 Javascript
JS获取url参数、主域名的方法实例分析
Aug 03 Javascript
解决jQuery ajax动态新增节点无法触发点击事件的问题
May 24 jQuery
详解一次Vue低版本安卓白屏问题的解决过程
May 30 Javascript
Vue项目打包压缩的实现(让页面更快响应)
Mar 10 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
64位windows系统下安装Memcache缓存
2015/12/06 PHP
Ajax PHP JavaScript MySQL实现简易无刷新在线聊天室
2016/08/17 PHP
THINKPHP3.2使用soap连接webservice的解决方法
2017/12/13 PHP
php实现数组中出现次数超过一半的数字的统计方法
2018/10/14 PHP
实例讲解php实现多线程
2019/01/27 PHP
formValidator3.3的ajaxValidator一些异常分析
2011/07/12 Javascript
JavaScript将XML转成JSON的方法
2015/03/12 Javascript
JavaScript中标识符提升问题
2015/06/11 Javascript
jQuery使用ajax跨域获取数据的简单实例
2016/05/18 Javascript
JS框架之vue.js(深入三:组件1)
2016/09/29 Javascript
Angular 2应用的8个主要构造块有哪些
2016/10/17 Javascript
微信小程序 实现列表项滑动显示删除按钮的功能
2017/04/13 Javascript
利用adb shell和node.js实现抖音自动抢红包功能(推荐)
2018/02/22 Javascript
对Vue- 动态元素属性及v-bind和v-model的区别详解
2018/08/27 Javascript
Vue按时间段查询数据组件使用详解
2020/08/21 Javascript
[06:24]DOTA2亚洲邀请赛小组赛第三日 TOP10精彩集锦
2015/02/01 DOTA
python基于BeautifulSoup实现抓取网页指定内容的方法
2015/07/09 Python
python安装PIL模块时Unable to find vcvarsall.bat错误的解决方法
2016/09/19 Python
TensorFlow变量管理详解
2018/03/10 Python
python实现得到当前登录用户信息的方法
2019/06/21 Python
python开发之anaconda以及win7下安装gensim的方法
2019/07/05 Python
Python3将jpg转为pdf文件的方法示例
2019/12/13 Python
Django中密码的加密、验密、解密操作
2019/12/19 Python
django实现模型字段动态choice的操作
2020/04/01 Python
使用pyplot.matshow()函数添加绘图标题
2020/06/16 Python
HTML5网页音乐播放器的示例代码
2017/11/09 HTML / CSS
西班牙三叶草药房:Farmacias Trébol
2019/05/03 全球购物
美国家居装饰网上商店:Lulu & Georgia
2019/09/14 全球购物
Java基础知识面试题
2014/03/25 面试题
三好学生个人先进事迹材料
2014/05/17 职场文书
旷课检讨书500字
2014/10/14 职场文书
先进教师个人总结
2015/02/11 职场文书
医学生自荐信范文
2015/03/05 职场文书
教你如何使用Python实现二叉树结构及三种遍历
2021/06/18 Python
Python基本知识点总结
2022/04/07 Python
什么是clearfix (一文搞清楚css清除浮动clearfix)
2023/05/21 HTML / CSS