提高js字符串连接的性能

转贴来自:http://hi.baidu.com/x8online/blog/item/5a3e20d3d1814d013bf3cfce.html

方法:定义一个StringBuffer类,在定义个方法(模拟C#中StringBuilder类)与直接使用连接字符相比

<script type="text/javascript">

     function StringBuffer()//使用构造函数
     {
        this._strings_=new Array;
     }
     StringBuffer.prototype.append=function (str)//使用原型定义函数属性
     {
      this._strings_.push(str);
     }
     StringBuffer.prototype.toString=function ()//使用原型定义函数属性
     {
      return this._strings_.join("");
     }
  
     var buffer=new StringBuffer();//使用类
     d1=new Date();
     for(var i=0;i<10000;i++)
     {
      buffer.append("text");
     }
     var result=buffer.toString();
     d2=new Date();
     document.write ("<br>Concatenation with StringBuffer:"+(d2.getTime()-d1.getTime())+"milliseconds<br>");
     ////////////////////////////////////////////////////////////////////////////////////////////////////////////////
     var d1=new Date();
     var str="";
     for(var i=0;i<10000;i++)
     {
      str+="text";
     }
     var d2=new Date();
     document.write ("<br>Concatenation with StringBuffer:"+(d2.getTime()-d1.getTime())+"milliseconds");
  
</script>

 

结果:Concatenation with StringBuffer:110milliseconds

           Concatenation with StringBuffer:2422milliseconds

以上结果经测试正确,结果StringBuffer比直接使用连接字符节省100%~200%的时间

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值