时间:2021-05-26
第一种:用连接符“+”连接字符串
str="a";
str+="b";
这种方法相对以下两种,最便捷快速。建议100字符以下的连接使用这种连接方式。
第二种:以数组作为中介,使用jion函数进行连接
var arr=new Array();arr.push(a);arr.push(b);var str=arr.join("");第三种:利用对象属性连接字符串
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
总结
以上所述是小编给大家介绍的Javascript三种字符串连接方式及性能比较,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1如何进行字符串连接?首先让我们来回顾一下字符串连接的两种常用方法:1.1使用字符串连接运算符常用的语言(如Java、C#、PHP等)都有字符串连接运算符,Ja
php大致有三种字符串连接:1、直接用.来进行连接。2、用.=进行连接。3、先压入数组,再通过join函数连接。下面分别对这三种方法的效率进行测试:第一种方法代
工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方法,这里将它们一一列出顺便也对它们的性能做个具体的比较。第一种方法用
python字符串过滤性能比较5种方法比较总共比较5种方法。直接看代码:importrandomimporttimeimportosimportstringba
字符串连接函数:字符串连接就是将一个字符串连接到另一个字符串的末尾,使其组合成一个新的字符串,在字符串处理函数中,strcat函数具有字符串连接功能。下面是用C