程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php優化及高效提速問題的實現方法第1/2頁

php優化及高效提速問題的實現方法第1/2頁

編輯:關於PHP編程

一、 在函數中,傳遞數組時使用 return 比使用 global 要高效,比如:
function userloginfo($usertemp){
$detail=explode("|",$usertemp);
return $detail;
}
$login=userloginfo($userdb);
  比
function userloginfo($usertemp){
global $detail;
$detail=explode("|",$usertemp);
}
userloginfo($userdb);
  要高效
二、 (這個代碼用於得到程序目錄對應的網址,推薦使用)
$urlarray=explode('/',$HTTP_SERVER_VARS['REQUEST_URI']);
$urlcount=count($urlarray);unset($urlarray[$urlcount-1]);
$ofstarurl='http://'.$HTTP_SERVER_VARS['HTTP_HOST'].implode('/',$urlarray);
  這段代碼比
$pre_urlarray=explode('/',$HTTP_SERVER_VARS['HTTP_REFERER']);
$pre_url=array_pop($pre_urlarray);
  要高效
三、 在循環中判斷時,數值判斷使用恆等要比等於高效
  $a=2;$b=2;
  比如
if($a==$b)$c=$a;
  比
if($a===$b)$c=$a;
  高效
四、 MySQL 查詢時盡量使用where in 少用 limit
  limit查多記錄的前幾條, 速度很快, 但是查詢最面幾條就會慢
  使用in .在查詢連續性記錄,非常快, 非連續性記錄第一次運行會稍微慢一點,但是之後將比較快!
五、 NT服務器數據操作穩定性不及unix/Linux
六、 輸出前使用盡量使用 ob_start();
可以加快輸出速度,適用NT或nuli/linux,對unlix類服務器 如果使用 ob_start('ob_gzhandler');輸出效率將更高
七、 判斷的時候盡量使用if($a==他的值)
否定的時候盡量使用if(empty($a)),因為這樣程序運行更快速
八、 使用不等時 != 與 <>效率相當
九、 個人經驗得 使用 $a="11111111111111"; 的效率和 $a='11111111111111'; 相當.並不象書本說的相差很大
十、 使用規范的SQL語句, 會有利於MySQL的解析
十一、 使用
if($online){
$online1=$online;
setcookie('online1',$online,$cookietime,$ckpath,$ckdomain,$secure);
}
  COOKIE將馬上生效
  使用
if($online)
setcookie('online1',$online,$cookietime,$ckpath,$ckdomain,$secure);
  COOKIE需要再刷新一次才能生效
十二、 使用
$handle=fopen($filename,wb);
flock($handle,LOCK_SH);
$filedata=fread($handle,filesize($filename));
fclose($handle);
  比
file($filename);
  無論在速度還是穩定上都要優秀

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved