作家
登录

JS字符串累加Array不一定比字符串累加快(根据电脑配置)

作者: 来源:www.28hudong.com 2013-03-30 00:29:36 阅读 我要评论

先贴出完整代码. 复制代码 代码如下: <script type="text/javascript"> function StringBuffer() { this._strings = new Array(); } StringBuffer.prototype.append = function(str) { this._strings.push(str); //StringBuffer.prototype.length = this._strings.length;//每多一行,就会多消耗处理时间 var i = "asdfasdf"; } StringBuffer.prototype.toString = function() { this._strings.join(""); } /*String类 + 号累加*/ var d = new Date();//累加开始时间 var str = "1"; for (var i = 0; i < 200; i++) { str += "ssss"; for (var i = 0; i < 30000; i++) { str += "text"; } } var d2 = new Date(); //累加结束时间 document.write("+:"+(d2.getTime() - d.getTime()) + "milliseconds");//累加30000用时 /*自定义StringBuffer类 字符串累加*/ d = new Date(); //StringBuffer开始时间 var buffer = new StringBuffer(); for (var i = 0; i < 200; i++) { str += "ssss"; for (var i = 0; i < 30000; i++) { buffer.append("text"); } } var resultstr = buffer.toString(); d2 = new Date(); document.write("<br/>StringBuffer:" + (d2.getTime() - d.getTime()) + "milliseconds"); /*直接使用Array 不进行封装*/ d = new Date(); var arr = new Array(); for (var i = 0; i < 200; i++) { str += "ssss"; for (var i = 0; i < 30000; i++) { arr.push("text"); } } var resStr = arr.join(""); d2 = new Date(); document.write("<br/>Array:" + (d2.getTime() - d.getTime()) + "milliseconds"); </script> [code] 先说下我的机器配置 如图1:。 运行时间结果 如图2:在一台N老的机子上运行结果 如图3:上面一堆的代码和图可能乱了。总结如下: 机器配置较低时:“+”字符串拼接方式消耗时间明显高于Array 方式 机器配置较高时:“+”字符串拼接方式消耗时间可能会与Array方式持平。甚者会更短. 总结:为了保险起见。还是推荐使用Array 来进行字符串拼接操作.

  推荐阅读

  Firefox中beforeunload事件的实现缺陷浅析

beforeunload 指在页面卸载前提供的最后一次JS执行的机会。如下 复制代码 代码如下: window.onbeforeunload = function() { return '您正在编辑的博客尚未保存,确定要离开此页吗?'; }; 可以使用返回值文字来提示>>>详细阅读


本文标题:JS字符串累加Array不一定比字符串累加快(根据电脑配置)

地址:http://www.17bianji.com/kaifa2/JS/23442.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)