Celebrate what you've accomplished, but raise the bar a little higher each time you succeed.php
若是一個方法能被靜態,那就聲明他爲靜態的,速度可提升1/4;html
靜態方法在程序開始時生成內存,可是多了會比實例方法多佔用內存,同時不能夠自動銷燬mysql
echo的效率高於print,由於echo沒有返回值,print返回一個整型;算法
echo大字符串時,若沒有作調整就嚴重影響性能。sql
打開Apache的mod_deflate進行壓縮 | ob_start先將內容放進緩衝區數據庫
在循環以前設置循環的最大次數,而非在在循環中;apache
銷燬變量去釋放內存,特別是大的數組;數組
因爲zend引擎,php的數組&對象特別佔內存緩存
php數組的內存利用率只有1/10服務器
避免使用像__get, __set, __autoload等魔術方法;
若是__autoload不能高效的將類名與實際的磁盤文件(不只僅是文件名)對應起來,系統將作大量文件是否存在(include path中包含的路徑)的判斷,於是須要大量IO操做
因此須要一套清晰的將類名與實際磁盤文件映射的機制
requiere_once()比較耗資源;
由於require_once須要判斷該文件是否被引用過
使用require/include方法避免
在includes和requires中使用絕對路徑,這樣在分析路徑花的時間更少;
若是包含相對路徑,php會在include_path裏面遍歷查找文件
絕對路徑能夠避免此類問題,所以解析操做系統路徑所需時間會少
若是你須要獲得腳本執行時的時間,$_SERVER['REQUEST_TIME']優於time();
前者是直接常量,後者須要執行函數
能使用字符處理函數的,儘可能用他們,由於效率高於正則;
how grep work
str_replace字符替換比正則替換preg_replace
快,但strtr
比str_replace
又快1/4;
str_replace會爲期參數分配內存
OPT: 用strpos先查找,看是否須要替換,若是須要再替換,效率差異在0.1%
若是一個函數既能接受數組又能接受簡單字符作爲參數,例如字符替換,而且參數列表不是太長,能夠考慮多用一些簡潔的替換語句,一次只替換一個字符,而不是接受數組作爲查找和替換參數。大事化小,1+1>2;
用@掩蓋錯誤會下降腳本運行速度;
$row['id']比$row[id]速度快7倍,建議養成數組鍵加引號的習慣;
錯誤信息頗有用;
在循環裏別用函數,例如For($x=0; $x < count($array); $x), count()函數在外面先計算;
在方法裏創建局部變量速度最快,幾乎和在方法裏調用局部變量同樣快;
局部變量是存在棧中的,當一個函數佔用的棧空間不大,這部份內存可能所有命中cache
若是一個函數裏使用了全局和局部變量,當兩段地址相差較大時,cpu cache須要來回切
創建一個全局變量要比局部變量要慢2倍;
創建一個對象屬性(類裏面的變量)例如($this->prop++)比局部變量要慢3倍;
創建一個未聲明的局部變量要比一個初始化的局部變量慢9-10倍;(NOTICE)
聲明一個未被任何一個函數使用過的全局變量也會使性能下降(和聲明相同數量的局部變量同樣),PHP可能去檢查這個全局變量是否存在;
方法的性能和在一個類裏面定義的方法的數目沒有關係,由於我添加10個或多個方法到測試的類裏面(這些方法在測試方法的先後)後性能沒什麼差別;(the way of call method)
在子類裏方法的性能優於在基類中;
只調用一個參數而且函數體爲空的函數運行花費的時間等於7-8次$localvar++運算,而一個相似的方法(類裏的函數)運行等於大約15次$localvar++運算;(Time consumption)
Surrounding your string by ‘ instead of 」 will make things interpret a little faster since php looks for variables inside 「…」 but not inside ‘…’. Of course you can only do this when you don’t need to have variables in the string.(使用‘代替「會運行的更快)
GOOD: $type = 'mixed';
GOOD: $outp = 'This is a '.$type.' string';
當輸出字符串時用逗號代替點分割更快些。注意:這隻對echo起做用,這個函數能接受一些字符串做爲參數;
Based on the run method of echo
在apache服務器裏一個php腳本頁面比相應的HTML靜態頁面生成至少要多花2-10倍的時間,建議多用些靜態HTML頁面和少許的腳步;
除非你的安裝了緩存,否則你的php腳本每次被訪問都須要被重編譯。建議安裝個php緩存程序,這樣經過去除一些重複的編譯來很明顯的提升你20-100%的性能;
建議用memcached,高性能的分佈式內存對象緩存系統,提升動態網絡應用程序性能,減輕數據庫的負擔;
對運算碼(OP code)的緩存頗有用,使得腳本沒必要爲每一個請求從新編譯
使用ip2long()和long2ip()函數把IP地址轉成整型存放進數據庫而非字符型。這幾乎能下降1/4的存儲空間。同時能夠很容易對地址進行排序和快速查找;
Through the int instead of string could get a higher search and sorting
使用checkdnsrr()經過域名存在性來確認部分email地址的有效性,這個內置函數能保證每個的域名對應一個IP地址;
not available on Win
若是你在使用php5和mysql4.1以上的版本,考慮使用mysql_的改良函數mysqli_;
試着喜歡使用三元運算符(?:);
在你想在完全重作你的項目前,看看PEAR有沒有你須要的。PEAR是個巨大的資源庫,不少php開發者都知道;
使用highlight_file()能自動打印一份很好格式化的頁面源代碼的副本;
使用error_reporting(0)函數來預防潛在的敏感信息顯示給用戶。理想的錯誤報告應該被徹底禁用在php.ini文件裏。但是若是你在用一個共享的虛擬主機,php.ini你不能修改,那麼你最好添加error_reporting(0)函數,放在每一個腳本文件的第一行(或用require_once()來加載)這能有效的保護敏感的SQL查詢和路徑在出錯時不被顯示;
使用 gzcompress() 和gzuncompress()對容量大的字符串進行壓縮(解壓)再存進(取出)數據庫時。這種內置的函數使用gzip算法能壓縮到90%;
經過參數變量地址得引用來使一個函數有多個返回值。你能夠在變量前加個「&」來表示按地址傳遞而非按值傳遞;
Like C
Fully understand 「magic quotes」 and the dangers of SQL injection. I’m hoping that most developers reading this are already familiar with SQL injection. However, I list it here because it’s absolutely critical to understand. If you’ve never heard the term before, spend the entire rest of the day googling and reading.(Removed as of PHP 5.4.0)
使用strlen()由於要調用一些其餘操做例如lowercase和hash表查詢因此速度不是太好,咱們能夠用isset()來實現類似的功能,isset()速度優於strlen();
strlen只返回在zval結構中存儲的已知字符串長度。
strlen調用通過:字母小寫化,哈希查找,會跟隨被調用的函數一塊兒執行
eg: if(strlen($foo) < 5) instead of if(!isset($foo{5}))
When incrementing or decrementing the value of the variable $i++ happens to be a tad slower then ++$i. This is something PHP specific and does not apply to other languages, so don’t go modifying your C or Java code thinking it’ll suddenly become faster, it won’t. ++$i happens to be faster in PHP because instead of 4 opcodes used for $i++ you only need 3. Post incrementation actually causes in the creation of a temporary var that is then incremented. While pre-incrementation increases the original value directly. This is one of the optimization that opcode optimized like Zend’s PHP optimizer. It is a still a good idea to keep in mind since not all opcode optimizers perform this optimization and there are plenty of ISPs and servers running without an opcode optimizer.
++$i只使用3條指令(opcode),而$i++須要4條,
不要隨便複製預約義變量,會形成內存的雙倍使用。
BAD : $name = $_POST['name']; echo $name;
GOOD: echo $_POST['name'];
用file_get_contents代替file, open, feof, fgets。
儘可能少進行文件操做。
優化SELECT SQL語句,儘可能少進行INSERT,UPDATE。
儘量的使用PHP內部函數。
循環內部不要聲明變量,尤爲是大變量:對象。
多維數組儘可能不要循環嵌套賦值。
foreach效率高於while & for。
用$i += 1 代替 $i = $i + 1;
對global變量,用完就要unset掉。
若是在代碼中存在大量耗時的函數,能夠考慮用C擴展的方式實現他們。
打開apache的mod_deflate模塊,能夠提升網頁的瀏覽速度。
echo的大變量問題
數據庫鏈接使用完畢即關掉,不要用長鏈接。
split比explode快
參考