首页 > web前端 > js教程 > 正文

JavaScript中String和StringBuffer的速度之争_javascript技巧

php中文网
发布: 2016-05-16 18:30:50
原创
944人浏览过

显示情况时Javascript中并没有StringBuffer类,一种主流的Javascript StringBuffer类的实现是通过prototype构造一个StringBuffer类。
StringBuffer.js

复制代码 代码如下:

function StringBuffer(){
this.content = new Array;
}
StringBuffer.prototype.append = function( str ){
this.content.push( str );
}
StringBuffer.prototype.toString = function(){
return this.content.join("");
}

现在让我们写一个测试用例:
TestStringBUffer.html
复制代码 代码如下:



test

<script> <BR>function testStringBuffer(){ <BR>var date1 = new Date(); <BR>var str; <BR>for( var i=0; i<10000; i++){ <BR>str += "text"; <BR>} <BR>var date2 = new Date(); <BR>document.writeln("Sting use time:"+ (date2 - date1) +"ms"); <BR>var date3 = new Date(); <BR>var strBuffer = new StringBuffer(); <BR>for(i=0; i<10000; i++){ <BR>strBuffer.append("text"); <BR>} <BR>strBuffer.toString(); <BR>var date4 = new Date(); <BR>document.writeln("<br/>StringBuffer use time:"+ (date4 - date3) +"ms"); <BR>} <BR></script>






现在让我们来测试下,看看会有什么发生:
IE8:
Sting use time:11ms
StringBuffer use time:47ms
结果是StringBuffer不但没有比String效率高,反而使低了不少。难道是前辈们错了?
那让我们再在别的浏览器中看看吧:
IE7:
Sting use time:266ms
StringBuffer use time:78ms
IE7中StringBuffer的优势很明显。
可以看到,在现在的主流浏览器中,都对String类的字符串连接作了优化,所以性能要好于自定义的StringBuffer类,但是在比较老的浏览器中,StringBuffer类的优势仍然很明显。具体在实际中就需要对浏览器进行判断。
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号