PHP程序性能優化的50種方法
- 用單引號代替雙引號來包含字符串,這樣作會更快一些。由於 PHP 會在雙引號包圍的 字符串中搜尋變量,單引號則不會,注意:只有 echo 能這麼作,它是一種能夠把多個字符 串看成參數的「函數」(譯註:PHP 手冊中說 echo 是語言結構,不是真正的函數,故把函數 加上了雙引號)。
- 若是能將類的方法定義成 static,就儘可能定義成 static,它的速度會提高將近 4 倍。
- $row[‘id’] 的速度是$row[id]的 7 倍
- echo 比 print 快,而且使用 echo 的多重參數(譯註:指用逗號而不是句點)代替字符串 鏈接,好比 echo $str1,$str2。
- 在執行 for 循環以前肯定最大循環數,不要每循環一次都計算最大值,最好運用 foreach 代替
- 註銷那些不用的變量尤爲是大數組,以便釋放內存。
- 儘可能避免使用__get,__set,__autoload。
- require_once()代價昂貴。
- include 文件時儘可能使用絕對路徑,由於它避免了 PHP 去 include_path 裏查找文件的速 度,解析操做系統路徑所需的時間會更少。
- 若是你想知道腳本開始執行(譯註:即服務器端收到客戶端請求)的時刻,使用 $_SERVER[‘REQUEST_TIME’] 要好於 time()
- 函數代替正則表達式完成相同功能。
- str_replace 函數比 preg_replace 函數快,但 strtr 函數的效率是 str_replace 函數的四倍。
- 若是一個字符串替換函數,可接受數組或字符做爲參數,而且參數長度不太長,那麼 能夠考慮額外寫一段替換代碼, 使得每次傳遞參數是一個字符, 而不是隻寫一行代碼接受數 組做爲查詢和替換的參數。
- 使用選擇分支語句(譯註:即 switch case)好於使用多個 if,else if 語句。
- 用@屏蔽錯誤消息的作法很是低效,極其低效。
- 打開 apache 的 mod_deflate 模塊,能夠提升網頁的瀏覽速度。
- 數據庫鏈接當使用完畢時應關掉,不要用長鏈接。
- 錯誤消息代價昂貴。
- 在方法中遞增局部變量,速度是最快的。幾乎與在函數中調用局部變量的速度至關。
- 遞增一個全局變量要比遞增一個局部變量慢 2 倍。
- 遞增一個對象屬性(如:$this->prop++)要比遞增一個局部變量慢 3 倍。
- 遞增一個未預約義的局部變量要比遞增一個預約義的局部變量慢 9 至 10 倍。
- 僅定義一個局部變量而沒在函數中調用它,一樣會減慢速度(其程度至關於遞增一個局 部變量)。PHP 大概會檢查看是否存在全局變量。
- 方法調用看來與類中定義的方法的數量無關,由於我(在測試方法以前和以後都)添加了 10 個方法,但性能上沒有變化。
- 派生類中的方法運行起來要快於在基類中定義的一樣的方法。
- 調用帶有一個參數的空函數,其花費的時間至關於執行 7 至 8 次的局部變量遞增操做。 相似的方法調用所花費的時間接近於 15 次的局部變量遞增操做。
- Apache 解析一個 PHP 腳本的時間要比解析一個靜態 HTML 頁面慢 2 至 10 倍。儘可能 多用靜態 HTML 頁面,少用腳本。
- 除非腳本能夠緩存,不然每次調用時都會從新編譯一次。引入一套 PHP 緩存機制一般 能夠提高 25%至 100%的性能,以避免除編譯開銷。
- 儘可能作緩存,可以使用 memcached。memcached 是一款高性能的內存對象緩存系統, 可用來加速動態 Web 應用程序,減輕數據庫負載。對運算碼 (OP code)的緩存頗有用,使 得腳本沒必要爲每一個請求作從新編譯。
- 當操做字符串並須要檢驗其長度是否知足某種要求時, 你想固然地會使用 strlen()函數。 此函數執行起來至關快,由於它不作任何計算,只返回在 zval 結構(C 的內置數據結構,用 於存儲 PHP 變量)中存儲的已知字符串長度。可是,因爲 strlen()是函數,多多少少會有些 慢,由於函數調用會通過諸多步驟,如字母小寫化(譯註:指函數名小寫化,PHP 不區分函 數名大小寫)、哈希查找,會跟隨被調用的函數一塊兒執行。在某些狀況下,你可使用 isset() 技巧加速執行你的代碼。 (舉例以下) if (strlen($foo) < 5) { echo 「Foo is too short」$$ } (與下面的技巧作比較) if (!isset($foo{5})) { echo 「Foo is too short」$$ } 調用 isset()恰巧比 strlen()快,由於與後者不一樣的是,isset()做爲一種語言結構,意味着它 的執行不須要函數查找和字母小寫化。 也就是說, 實際上在檢驗字符串長度的頂層代碼中你 沒有花太多開銷。
- 當執行變量$i 的遞增或遞減時,$i++會比++$i 慢一些。這種差別是 PHP 特有的,並不 適用於其餘語言, 因此請不要修改你的 C 或 Java 代碼並期望它們能當即變快, 沒用的。 ++$i 更快是由於它只須要 3 條指令(opcodes),$i++則須要 4 條指令。後置遞增實際上會產生一 個臨時變量,這個臨時變量隨後被遞增。而前置遞增直接在原值上遞增。這是最優化處理的 一種,正如 Zend 的 PHP 優化器所做的那樣。牢記這個優化處理不失爲一個好主意,由於 並非全部的指令優化器都會作一樣的優化處理, 而且存在大量沒有裝配指令優化器的互聯 網服務提供商(ISPs)和服務器。
- 並非事必面向對象(OOP),面向對象每每開銷很大,每一個方法和對象調用都會消耗很 多內存。
- 並不是要用類實現全部的數據結構,數組也頗有用。
- 不要把方法細分得過多,仔細想一想你真正打算重用的是哪些代碼?
- 當你須要時,你總能把代碼分解成方法。
- 儘可能採用大量的 PHP 內置函數。
- 若是在代碼中存在大量耗時的函數,你能夠考慮用 C 擴展的方式實現它們。
- 評估檢驗(profile)你的代碼。 檢驗器會告訴你, 代碼的哪些部分消耗了多少時間。 Xdebug 調試器包含了檢驗程序,評估檢驗整體上能夠顯示出代碼的瓶頸。
- mod_zip 可做爲 Apache 模塊,用來即時壓縮你的數據,並可以讓數據傳輸量下降 80%。
- 在能夠用 file_get_contents 替代 file、fopen、feof、fgets 等系列方法的狀況下,儘可能 用 file_get_contents,由於他的效率高得多!可是要注意 file_get_contents 在打開一個 URL 文件時候的 PHP 版本問題;
- 儘可能的少進行文件操做,雖然 PHP 的文件操做效率也不低的;
- 優化 Select SQL 語句,在可能的狀況下儘可能少的進行 Insert、Update 操做;
- 儘量的使用 PHP 內部函數(可是我卻爲了找個 PHP 裏面不存在的函數,浪費了本可 以寫出一個自定義函數的時間,經驗問題啊!);
- 循環內部不要聲明變量, 尤爲是大變量: 對象(這好像不僅是 PHP 裏面要注意的問題吧?);
- 多維數組儘可能不要循環嵌套賦值;
- 在能夠用 PHP 內部字符串操做函數的狀況下,不要用正則表達式;
- foreach 效率更高,儘可能用 foreach 代替 while 和 for 循環;
- 用單引號替代雙引號引用字符串;
- 用 i+=1 代替 i=i+1。符合 c/c++的習慣,效率還高
- 對 global 變量,應該用完就 unset()掉;
歡迎關注本站公眾號,獲取更多信息