«
PHP程序优化及高效提速问题

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


   <p>  传递数组时使用 return 比使用 global 要高效,比如:</p><code>function userloginfo($usertemp){<br />$detail=explode("",$usertemp);<br />return $detail;<br />}<br />$login=userloginfo($userdb);</code><p>  比</p><code>function userloginfo($usertemp){<br />global $detail;<br />$detail=explode("",$usertemp);<br />}<br />userloginfo($userdb);</code><p>  要高效</p><p>  二、 (这个代码用于得到程序目录对应的网址,推荐使用)</p><code>$urlarray=explode('/',$HTTP_SERVER_VARS['REQUEST_URI']);<br />$urlcount=count($urlarray);unset($urlarray[$urlcount-1]);<br />$ofstarurl='http://'.$HTTP_SERVER_VARS['HTTP_HOST'].implode('/',$urlarray);</code><p>  这段代码比</p><code>$pre_urlarray=explode('/',$HTTP_SERVER_VARS['HTTP_REFERER']);<br />$pre_url=array_pop($pre_urlarray);</code><p>  要高效</p><p>  三、 在循环中判断时,数值判断使用恒等要比等于高效</p><p>  $a=2;$b=2;</p><p>  比如</p><p>  if($a==$b)$c=$a;</p><p>  比</p><p>  if($a===$b)$c=$a;</p><p>  高效</p><p>  四、 mysql 查询时尽量使用where in 少用 limit</p><p>  limit查多记录的前几条, 速度很快, 但是查询最面几条就会慢</p><p>  使用in .在查询连续性记录,非常快, 非连续性记录第一次运行会稍微慢一点,但是之后将比较快!</p><p>  五、 NT服务器数据操作稳定性不及unix/linux</p><p>  六、 输出前使用尽量使用 ob_start(); 可以加快输出速度,适用NT或nuli/linux,对unlix类服务器 如果使用 ob_start('ob_gzhandler');输出效率将更高</p><p>  七、 判断的时候尽量使用if($a==他的值) 否定的时候尽量使用if(empty($a)),因为这样程序运行更快速</p><p>  八、 使用不等时 != 与 <> 效率相当</p><p>  九、 个人经验得 使用 $a="11111111111111"; 的效率和 $a='11111111111111'; 相当.并不象书本说的相差很大</p><p>  十、 使用规范的SQL语句, 会有利于MySQL的解析</p><p>  十一、 使用</p><code>if($online){<br />$online1=$online;<br />setcookie('online1',$online,$cookietime,$ckpath,$ckdomain,$secure);<br />}</code><p>  COOKIE将马上生效</p><p>  使用</p><code>if($online)<br />setcookie('online1',$online,$cookietime,$ckpath,$ckdomain,$secure);</code><p>  COOKIE需要再刷新一次才能生效</p>