简明现代魔法 -> JavaScript -> 腾迅关于长字符串连接的面试题

腾迅关于长字符串连接的面试题

2010-07-23

腾讯的一道javascript面试题:

请指出一下代码的性能问题,并进行优化。

<script language="javascript">
var info="腾讯拍拍网(www.paipai.com)是腾讯旗下知名电子商务网站。";
info +="拍拍网于2005年9月12日上线发布,";
info +="2006年3月13日宣布正式运营,";
info +="是目前国内第二大电子商务平台。";
info=info.split(",");
for(var i=0; i<info.length; i++)
{
	alert(info[i]);
}
</script>

这题初看纯属折腾,因为后面要根据逗号分隔再alert每项,何不构造一个数组对象来存放文本内容,而要用个临时变量info才存放。

如var info=["腾讯拍拍网(www.paipai.com)是腾讯旗下知名电子商务网站。","拍拍网于2005年9月12日上线发布,","2006年3月13日宣布正式运营,","是目前国内第二大电子商务平台。"] 。可是后来想如果是优化的话这个题目就出的没意义了。

仔细观察info这个变量,发现它每次都要自加字符串,如果字符串很大的又很多的话会非常影响性能的。

对于js中的string类型,属于基本类型,因此一般情况下他们是存放在栈上的。如果字符串很大,info会每次变成一个很长的字符串,会很慢。

如果用引用类型数组来存放则好很多,如:

<script language="javascript">
var temp=[];
temp.push("腾讯拍拍网(www.paipai.com)是腾讯旗下知名电子商务网站。");
//temp只是一个指向堆上数组的指针
temp.push("拍拍网于2005年9月12日上线发布,"); 	
temp.push("2006年3月13日宣布正式运营,"); 
temp.push("是目前国内第二大电子商务平台。"); 
temp.join("");
alert(temp);
</script>

最后一招temp.join("")搞定。对处理大字符串连接问题都可以采取这种思路。

随机文章推荐
网站分类


注:如需转载本文,请注明出处(原文链接),谢谢。更多精彩内容,请进入简明现代魔法首页。

进入新博客
喜欢本文,就分享它吧
给我留言
您的名字:
您的邮件:
您的网站:


 

copyright © 2009 简明现代魔法    学习、分享、进步

power by Gonn 感谢所有关心和支持本站的朋友们