浅谈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特效 鼠标移动背景云变化
Dec 28 Javascript
在服务端(Page.Write)调用自定义的JS方法详解
Aug 09 Javascript
jquery弹出框的用法示例(2)
Aug 26 Javascript
表单序列化与jq中的serialize使用示例
Feb 21 Javascript
javascript的propertyIsEnumerable()方法使用介绍
Apr 09 Javascript
Javascript URI 解析介绍
Mar 15 Javascript
JavaScript模块规范之AMD规范和CMD规范
Oct 27 Javascript
vue2中filter()的实现代码
Jul 09 Javascript
vue2.0 兄弟组件(平级)通讯的实现代码
Jan 15 Javascript
在vue.js中使用JSZip实现在前端解压文件的方法
Sep 05 Javascript
vue实现多个元素或多个组件之间动画效果
Sep 25 Javascript
BootStrap中的模态框(modal,弹出层)功能示例代码
Nov 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句法规则详解 入门学习
2011/11/09 PHP
用php随机生成福彩双色球号码的2种方法
2013/02/04 PHP
php中get_headers函数的作用及用法的详细介绍
2013/04/27 PHP
Thinkphp实现MySQL读写分离操作示例
2014/06/25 PHP
PHP安装memcached扩展笔记
2015/05/28 PHP
纯css+js写的一个简单的tab标签页带样式
2014/01/28 Javascript
Jquery easyUI 更新行示例
2014/03/06 Javascript
JS基于Mootools实现的个性菜单效果代码
2015/10/21 Javascript
jQuery实现的分子运动小球碰撞效果
2016/01/27 Javascript
jQuery+PHP+MySQL实现无限级联下拉框效果
2016/02/19 Javascript
灵活的理解JavaScript中的this指向
2016/02/25 Javascript
jQuery利用sort对DOM元素进行排序操作
2016/11/07 Javascript
Vue resource中的GET与POST请求的实例代码
2017/07/21 Javascript
Vue 获取数组键名的方法
2018/06/21 Javascript
vue实现学生录入系统之添加删除功能
2018/07/11 Javascript
JavaScript实现新年倒计时效果
2018/11/17 Javascript
nodejs异步编程基础之回调函数用法分析
2018/12/26 NodeJs
jQuery移动端跑马灯抽奖特效升级版(抽奖概率固定)实现方法
2019/01/18 jQuery
详解小程序BackgroundAudioManager踩坑之旅
2019/12/08 Javascript
Nuxt 嵌套路由nuxt-child组件用法(父子页面组件的传值)
2020/11/05 Javascript
使用python3.5仿微软记事本notepad
2016/06/15 Python
Python制作钉钉加密/解密工具
2016/12/07 Python
python 调用c语言函数的方法
2017/09/29 Python
浅谈Python中带_的变量或函数命名
2017/12/04 Python
pyspark操作MongoDB的方法步骤
2019/01/04 Python
Pytorch 实现自定义参数层的例子
2019/08/17 Python
Django实现基于类的分页功能
2019/10/31 Python
CSS3制作苹果风格键盘特效
2015/02/26 HTML / CSS
优质美利奴羊毛袜,不只是徒步旅行:Darn Tough Vermont
2018/11/05 全球购物
党的群众路线教育实践活动心得体会900字
2014/03/07 职场文书
企业活动策划方案
2014/06/02 职场文书
2015年语文教研组工作总结
2015/05/23 职场文书
2015年卫生院健康教育工作总结
2015/07/24 职场文书
2019通用版劳动合同范本!
2019/07/11 职场文书
如何使用vue3打造一个物料库
2021/05/08 Vue.js
windows系统安装配置nginx环境
2022/06/28 Servers