程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php提高程序效率的24個小技巧

php提高程序效率的24個小技巧

編輯:關於PHP編程

  本文轉自《php必須知道的300個問題》一書,在此記錄方便以後查看

  (1)用單引號代替雙引號來包含字符串,這樣做會更快些。因為php會在雙引號包圍的字符串中搜尋變量,單引號則不會。注意:只有echo能這麼做,它是一種可以把多個字符串當做參數的“函數”(echo是語言結構,不是真正的函數)。

  (2)$row['id']的速度要比$row[id]快很多。

  (3)echo比print快,並且使用echo的多重參數代替字符串連接,比如:echo $str1,$str2

  (4)foreach效率更高,盡量用foreach代替while和for循環。

  (5)在執行for循環之前確定最大循環數,不要每循環一次都計算最大值,最好運用foreach代替。

  (6)注銷那些不用的變量,尤其是大數組,以便釋放內存。

  (7)盡量不要使用_get、_set、_autoload。

  (8)使用include()包含文件時,盡量使用絕對路徑,因為它省去了php去include_path中查找文件的時間,解析操作系統路徑所需的時間會更少。

  (9)如果想獲取腳本開始執行(即服務器端收到客戶端請求)的時間,使用$_SERVER['REQUEST_TIME']要優於time()。

  (10)在項目中盡量應用php內置函數實現功能,同事盡量使用函數代替正則表達式完成相同功能。

  (11)str_replace函數比preg_replace函數快,但strtr函數的效率比str_replace函數還要高。

  (12)使用選擇分支語句(switch)優於使用多個if,else if語句。

  (13)不提倡使用@屏蔽錯誤信息,它的效率非常低。

  (14)開啟Apache的mod_deflate模塊,可以提高網頁的浏覽速度。

  (15)在連接數據庫時,盡量使用短連接,要及時關閉使用完畢的數據庫連接。

  (16)在方法中遞增局部變量,速度是最快的。幾乎與在函數中調用局部變量的速度相當。

  (17)派生類中的方法運行起來要快於在基類中定義的同樣的方法。如果能將類的方法定義成static,就盡量定義成static,它的速度會提升很多。

  (18)盡量少進行文件操作,雖然php的文件操作效率也不低。

  (19)Apache解析一個php腳本的時間要比解析一個靜態HTML頁面慢很多。盡量多用靜態HTML頁面,少用php腳本。

  (20)除非腳本可以緩存,否則每次調用時都會重新編譯一次。引入一套php緩存機制通常可以提升25%~100%的性能,以免除編譯開銷。

  (21)當操作字符串並需要檢驗其長度是否滿足某種要求時,第一想法是使用strlen()函數。此函數執行起來速度快,因為它不做任何計算,只返回在zval結構(C的內置函數結構,用於儲存php變量)中存儲的已知字符串長度。但是,由於strlen()是函數,多多少少會有些慢,因為函數調用會經過諸多步驟。在某些情況下,可以使用isset()加速執行代碼。例如:

  <?php

    if(strlen($foo)<5){ echo "Foo is too short" $$}

    if(!isset($foo{5})){ echo "Foo is too short" $$}

  ?>

  調用isset()恰巧比strlen()快,因為與strlen()不同的是,isset()作為一種語言結構,意味著它的執行不需要函數查找和字母小寫化。也就是說,實際上在檢驗字符串長度的頂層代碼中沒有花太多開銷。

  (22)當執行變量$i的遞增或遞減時,$i++會比++$i慢一些(僅限php語言)

  (23)並不是事必面向對象(OOP),面向對象往往開銷很大,每個方法和對象調用都會消耗很多內存。

  (24)如果可以通過file_get_contents代替file、fopen、feof、fgets等系列方法的情況下,盡量用file_get_contents,因為它的效率要高很多。但是,要注意file_get_contents在打開一個URL文件時的php版本問題。

  以上內容,我尚未驗證過,提高效率神馬的,等我先學會低效率的傻瓜方法再說吧O(∩_∩)O哈!

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