直接用+=连接耗时17547毫秒,
使用Array.join()耗时234毫秒,比前者快了近75倍!
而且使用+=操作的话,随着循环次数的增加,耗用时间是nn倍的上升,循环30000次时近60秒,
而用Array.join循环50000次才是843毫秒。
javascript的string是固定内存的,每次对字符串的修改操作都会导致重新分配内存,速度当然慢了。
c#中的string也是固定分配内存的,所以在做多字符串连接时一定要记得StringBuilder哦.
<!
DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>
< html xmlns ="http://www.w3.org/1999/xhtml" >
< head >
< title > Untitled Page </ title >
</ head >
< body >
< input id ="Button1" type ="button" value ="直接连接" onclick ="compute1();" />
开始时间: < input id ="Text1" type ="text" /> 结束时间: < input id ="Text2" type ="text" />
耗时: < input id ="Text3" type ="text" />< br />
< br />
< input id ="Button2" type ="button" value ="StringBuilder" onclick ="compute2();" /> 开始时间: < input id ="Text4" type ="text" /> 结束时间: < input id ="Text5" type ="text" />
耗时:
< input id ="Text6" type ="text" />
</ body >
</ html >
< html xmlns ="http://www.w3.org/1999/xhtml" >
< head >
< title > Untitled Page </ title >
</ head >
< body >
< input id ="Button1" type ="button" value ="直接连接" onclick ="compute1();" />
开始时间: < input id ="Text1" type ="text" /> 结束时间: < input id ="Text2" type ="text" />
耗时: < input id ="Text3" type ="text" />< br />
< br />
< input id ="Button2" type ="button" value ="StringBuilder" onclick ="compute2();" /> 开始时间: < input id ="Text4" type ="text" /> 结束时间: < input id ="Text5" type ="text" />
耗时:
< input id ="Text6" type ="text" />
</ body >
</ html >
<
script language
=
javascript
>
function compute1()
{
var start = new Date();
window.document.all.Text1.value = start.getSeconds() * 1000 + start.getMilliseconds();
str = "" ;
for ( i = 0 ; i <2 0000 ; i ++ )
{
str += " wuchang@guet.edu.cn " ;
}
var end = new Date();
window.document.all.Text2.value = end.getSeconds() * 1000 + end.getMilliseconds();
window.document.all.Text3.value = Number(window.document.all.Text2.value) - Number(window.document.all.Text1.value);
}
function compute2()
{
var start = new Date();
window.document.all.Text4.value = start.getSeconds() * 1000 + start.getMilliseconds();
str = new StringBuilder();
for ( i = 0 ; i <2 00000 ; i ++ )
{
str.Append( " wuchang@guet.edu.cn " );
}
var end = new Date();
window.document.all.Text5.value = end.getSeconds() * 1000 + end.getMilliseconds();
window.document.all.Text6.value = Number(window.document.all.Text5.value) - Number(window.document.all.Text4.value);
}
function StringBuilder(str)
{
this .tmp = new Array();
}
StringBuilder.prototype.Append = function (value)
{
this .tmp.push(value);
return this ;
}
StringBuilder.prototype.Clear = function ()
{
tmp.length = 1 ;
}
StringBuilder.prototype.toString = function ()
{
return this .tmp.join('');
}
</ script >
function compute1()
{
var start = new Date();
window.document.all.Text1.value = start.getSeconds() * 1000 + start.getMilliseconds();
str = "" ;
for ( i = 0 ; i <2 0000 ; i ++ )
{
str += " wuchang@guet.edu.cn " ;
}
var end = new Date();
window.document.all.Text2.value = end.getSeconds() * 1000 + end.getMilliseconds();
window.document.all.Text3.value = Number(window.document.all.Text2.value) - Number(window.document.all.Text1.value);
}
function compute2()
{
var start = new Date();
window.document.all.Text4.value = start.getSeconds() * 1000 + start.getMilliseconds();
str = new StringBuilder();
for ( i = 0 ; i <2 00000 ; i ++ )
{
str.Append( " wuchang@guet.edu.cn " );
}
var end = new Date();
window.document.all.Text5.value = end.getSeconds() * 1000 + end.getMilliseconds();
window.document.all.Text6.value = Number(window.document.all.Text5.value) - Number(window.document.all.Text4.value);
}
function StringBuilder(str)
{
this .tmp = new Array();
}
StringBuilder.prototype.Append = function (value)
{
this .tmp.push(value);
return this ;
}
StringBuilder.prototype.Clear = function ()
{
tmp.length = 1 ;
}
StringBuilder.prototype.toString = function ()
{
return this .tmp.join('');
}
</ script >