«
php中关于处理字符串时效率的讨论

时间:2008-5-31    作者:Deri    分类: 分享


   <p>  有一堆类似以下变量$abc的字符串,末尾都多出来了一个,(逗号),我想去掉末尾的逗号,为了验证不同的处理方法的执行时间,以下是我写的一个对比程序进行试验:</p><p>  程序一,利用substr</p><code><?php<br />function getmicrotime(){ <br />    list($usec, $sec) = explode(" ",microtime()); <br />    return ((float)$usec + (float)$sec); <br />  }<br />  <br />$time_start = getmicrotime();</code><p>  $abc="重庆,万州,涪陵,渝中,大渡口,江北,沙坪坝,九龙坡,南岸,北碚,万盛,双挢,渝北,巴南,黔江,长寿,綦江,潼南,铜梁,大足,荣昌,壁山,梁平,城口,丰都,垫江,武隆,忠县,开县,云阳,奉节,巫山,巫溪,石柱,";</p><code>$l=strlen($abc);<br />$abc=substr($abc,0,$l-1);<br />echo $abc."<br>";<br />$time_end = getmicrotime();<br />echo ($time_end-$time_start)*1000;<br />?></code></p><p>  程序二,利用正则表达式</p><code><?php<br />function getmicrotime(){ <br />    list($usec, $sec) = explode(" ",microtime()); <br />    return ((float)$usec + (float)$sec); <br />  }<br />  <br />$time_start = getmicrotime();</code><p>  $abc="重庆,万州,涪陵,渝中,大渡口,江北,沙坪坝,九龙坡,南岸,北碚,万盛,双挢,渝北,巴南,黔江,长寿,綦江,潼南,铜梁,大足,荣昌,壁山,梁平,城口,丰都,垫江,武隆,忠县,开县,云阳,奉节,巫山,巫溪,石柱,";</p><code>$abc=str_replace(",$","",$abc);<br />echo $abc."<br>";<br />$time_end = getmicrotime();<br />echo ($time_end-$time_start)*1000;<br />?></code></p><p>  结果程序一的执行平均时间为0.045,程序二的执行平均时间为0.085。不进行任何处理的平均执行时间为0.041</p><p>  可见利用第一种方法处理效率要高出尽50%</p><p>  由此,我们在做程序的过程中,尤其是在要求高效的程序中,我们应该对不同的方法进行一下对比,找出最优化的处理方法。</p>