您的位置:首页 > Web前端 > JavaScript

javascript中字符串累加的性能优化(String和StringBuffer)

2008-09-21 22:45 567 查看
function StorePage(){d=document;t=d.selection?(d.selection.type!='None'?d.selection.createRange().text:''):(d.getSelection?d.getSelection():'');void(keyit=window.open('http://www.365key.com/storeit.aspx?t='+escape(d.title)+'&u='+escape(d.location.href)+'&c='+escape(t),'keyit','scrollbars=no,width=475,height=575,left=75,top=20,status=no,resizable=yes'));keyit.focus();}在JAVA中操作N个字符串累加或许会使用:

String strs = "";
for(int i = 0; i<2000; i++) {
strs += "my test";
}

稍微有点编程经验的可能就会使用StringBuffer类来累加字符串,例如:

StringBuffer strs = new StringBuffer();
for(int i = 0; i<2000; i++) {
strs.append("my text");
}

性能大家测试一下就知道了,根据机器配置的不同时间差可能会不一样;

下面我们来看看javascript中如何使用:

在javascript中只有String对象而没有设计StringBuffer对象,那我们就来自己设计一个StringBuffer对象

function StringBuffer(){
this._strings_ = new Array();
}

StringBuffer.prototype.append = function(str) {
this._strings_.push(str);
}

StringBuffer.prototype.toString = function() {
return this._strings_.join("");
}

这个StringBuffer对象只有两个方法,一个是增加字符串,一个是输出累加的字符串结果,原理就是使用数组暂存累加的字符串内容最后再做字符串的链接操作,这样就把String对象中的累加操作省掉了,下面是20000次循环后的结果:

累加字符串共消耗1218毫秒
StringBuffer共消耗188毫秒

经测试差距在4-10倍之间,效率就很明显了,呵呵
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: