在 PHP 7 中不要做的 10 件事

pythontab發表於2016-10-30

1. 不要使用 mysql_ 函式

這一天終於來了,從此你不僅僅“不應該”使用mysql_函式。PHP 7 已經把它們從核心中全部移除了,也就是說你需要遷移到好得多的mysqli_函式,或者更靈活的 PDO 實現。

2. 不要編寫垃圾程式碼

這一條可能易於理解,但是會變得越來越重要,因為 PHP 7 的速度提升可能會隱藏你的一些問題。不要僅僅滿足於你的站點速度,因為遷移到 PHP 7 才讓它變快。

為了理解速度有多重要,以及如何把事情做得更好,請看一看我們的文章速度優化入門指南。

作為一名開發者,你應該總是確保按需載入指令碼,儘可能連線它們,編寫高效的資料庫查詢,儘可能使用快取,以及其它。

3. 不要在檔案末尾使用 PHP 閉合標籤

你可以看一看,當一個檔案以 PHP 程式碼結尾時,WordPress 多數核心程式碼都把末尾的 PHP 標籤去掉了。實際上,Zend 框架特別禁止了它。PHP 並不需要檔案末尾的閉合標籤,並且我們可以通過去掉它來保證不會在後面新增任何的空白字元。

4. 不要做不必要的引用傳遞

我個人不喜歡引用傳遞。我知道有時候它很實用,但是其它情況下它使程式碼變得難懂,並且更難預測結果。

據說一些人認為它使程式碼執行更快,但是根據一些 PHP 高階程式設計師所說,這並不正確。

說明引用為什麼不好的一個例子是,PHP 內建了shuffle()和sort()。它們修改原始陣列,而不是返回處理後的陣列,這很不合邏輯。

5. 不要在迴圈中執行查詢

在迴圈中執行查詢非常浪費。它給你的系統施加不必要的壓力,並且可能能夠在迴圈外部更快獲得相同結果。當我遇到需要這樣的情況時,我通常會使用兩個分離的查詢來解決問題,我會使用它們來構建資料陣列。之後我會遍歷陣列,並不需要在這個過程中執行查詢。

由於 WordPress 適用於這裡,它可能有一些例外。雖然get_post_meta() 會從資料庫獲取大量資料,如果你正在遍歷某個特殊博文的後設資料你可以在迴圈中使用它。這是因為當你第一次呼叫它的時候,WordPress實際上會獲取所有後設資料並快取它們。後續的呼叫使用這些快取資料,沒有資料庫的呼叫。

弄懂這些的最佳方式是閱讀函式文件,以及使用類似 Query Monitor 的工具。

6. 不要在 SQL 查詢中使用 *

當然,這個更像 MySQL 的問題,但是我們習慣在 PHP 中編寫 SQL 程式碼,所以都差不多。無論如何,如果可以避免的話,不要在 SQL 查詢裡使用萬用字元,尤其是資料庫有很多列的時候。

你應該明確指定需要哪些行,並且僅僅獲取它們。這有助於減少所用資源,保護資料,以及讓事情變得儘可能清晰。

對於 SQL,你需要了解所有可用的函式,並且儘可能測試其速度。在計算均值、求和或計算類似數值時,要使用 SQL 函式而不是 PHP 函式。如果你不確定某個查詢的速度,測試它並且嘗試一些其它的編譯 — 之後使用最好的那個。

7. 不要信任使用者輸入

信任使用者輸入是不明智的。始終校驗、過濾、轉義、檢查並留好退路。使用者資料存在三個問題:我們開發者並沒有考慮每種可能性,它通常不正確,以及它可能是蓄意破壞。

經過周密考慮的系統可以防護這些威脅。要確保使用類似filter_var()的內建函式檢查適當的值,以及在處理資料庫時轉義(或預編譯)。

WordPress 擁有一些函式來解決問題。詳見文章校驗、轉義和過濾使用者資料。

8. 不要故作聰明

你的目標應該是編寫優雅的程式碼,來更清晰地表達你的意圖。你可能能夠通過將任何東西縮短為一個單詞的變數,使用多層的三元邏輯,以及其它手段,從每個頁面中優化 0.01 秒。但這隻會給你和你周圍的人產生大麻煩。

合理命名變數,為程式碼編寫文件,優先選擇清晰而不是簡潔。甚至還可以更好,使用標準的物件導向程式碼,它本身或多或少就是文件,不需要一大堆內聯數值。

9. 不要重新發明輪子

PHP 到現在為止有很長時間了,網站被造出來的時間更長。很可能無論你需要造出什麼,一些人之前早就造出來了。不要害怕向他人尋求支援,Github是你的好朋友,Composer也是,Packagist也是。

從日誌工具到調色工具,從效能分析器到單元測試框架,從 Mailchimp API 到 Twitter Bootstrap,每個東西都可以通過按下按鍵(或者敲下命令)來獲取,使用它們吧!

10. 不要忽略其它語言

如果你是個 PHP 程式設計師,現在有個好機會去至少了解 HTML、CSS、JavaScript 和 MySQL。當你能夠更好地處理這些語言時,就是重新學習 JavaScript 的時機了。JavaScript 並不是 jQuery,你應該合理地學習 JavaScript 來更高效地使用它。

我也打算向你推薦學習物件導向的 PHP,它可以節省時間,並且在程式碼規模更大時會變得更好。對於類似 C# 和 Java 的語言,在你瞭解 OOP 之後,它們也更易於理解。

通過了解包管理器、構建指令碼、CoffeeScript、LESS、SASS、YAML 、指令碼引擎和其它強大的工具來擴充套件你的知識面。我強烈向你推薦看一看其它框架,尤其是 Laravel。

當你使用它們出色完成任務時,學習 Ruby、RoR、Android、iPhone 和 Windows Phone 應用開發如何?你可能會認為這毫無意義,因為它們在你的舒適區和工作所需範圍之外,但是這就是它們的意義。每種語言都有一些要學習的實用的東西,以及從沒碰到的新知識。所有 PHP 頂級開發者都懂得很多其它程式語言,這並非偶然。

相關文章