2019年了,PHP已不再是當年那個「設計糟糕」的語言
作者 | Brent
譯者 | 張蘭月
這篇文章不在於解決關於 PHP 的那個永恆話題,而是想讓你了解,PHP 在這些年的進展以及那些值得關注的特性與發展現狀。
之前,有一篇非常流行的博客文章是「PHP:那些糟糕的設計」,第一次讀到這篇博客的時候,我正在一個非常破舊的地方工作,處理著許多 PHP 遺留項目。這篇博客對我觸動很深,我開始思考是否要停止編程,換一份完全不同的工作。文章地址:
https://eev.ee/blog/2012/04/09/php-a-fractal-of-bad-design/
幸運的是,很快我就換了一份工作,而 PHP 在 5.X 版本之後又有了很多新的改進。今天,我要向那些不再使用 PHP 編程,或者陷入遺留項目的人致敬。
劇透:直到今天,PHP 仍有很多糟糕的東西,例如許多核心功能仍然存在不一致的方法簽名,仍然存在令人混淆的配置設置,仍然會有一些開發者因為知識的缺乏而導致寫的代碼很糟糕等等。
但是,本文我想把目光集中在 PHP 已經改進的地方上面,以及如何寫出更加乾淨和易維護的 PHP 代碼。也許你不會改變對 PHP 的看法,但很有可能,你會驚訝於過去幾年 PHP 的進步。
要 點
PHP 每年都會推出一個新的版本;
自 PHP 5 代之後,其性能不斷提升;
有框架、包和平台組成的活躍生態系統;
過去幾年間,PHP 添加了許多新的特性,且現在仍在持續演進;
許多工具如靜態分析器也越發成熟,未來也將繼續發展。
更新:很多人希望我能夠展示一下實際代碼,這是我其中一個業餘項目的源代碼,它是用 PHP 和 Laravel 寫的,另外還有一個是我們在辦公室負責維護的上百個 OSS 包的列表。
https://github.com/brendt/aggregate.stitcher.io
https://spatie.be/open-source/packages
回顧歷史
讓我們先快速回顧一下 PHP 的版本發布周期。現在 PHP 的版本是 7.3,預計 2019 年末將發布 PHP 7.4,7.4 之後的版本將會是 PHP 8.0。
從 5.X 版本之後,PHP 核心團隊一直在努力每年發布一個新版本,並且在過去的 4 年間,這一目標一直完成得很好。
大致來說,每個新版本都會用 2 年時間進行積極地支持,然後用一年進行「安全修補」工作。這樣做的目的是促使 PHP 開發者儘可能保持最新狀態,例如每年都升級比從 5.4 直接跳到 7.0 要簡單得多。
PHP 具體的版本發布情況,可以查看:
https://www.php.net/supported-versions.php
搞清楚 PHP 的發展歷程後,我們來談談大家對 PHP 的常見誤解。
PHP 的性能
在 5.X 版本時代,PHP 的性能平均而言是最好的。而在 7.0 時代,大部分的 PHP 核心都從零開始重寫了,其性能能夠達到之前的 2-3 倍。口說無憑,幸運的是,有人花了大量時間來測量 PHP 的性能,Kinsta 提供了一個很好的更新列表。
從 7.0 版本以來,PHP 性能就只升不降。PHP web 應用的性能可以和其他語言 web 框架的性能相提並論,甚至更高。具體測試情況可查看:
https://github.com/the-benchmarker/web-frameworks
當然,PHP 框架的性能還無法超越 C 和 Rust,但是要比 Rails 或 Django 好,且能夠和 ExpressJS 相媲美。
框架和生態系統
在談到框架時,PHP 已經不再只是 WordPress 了。作為職業的 PHP 開發者,我認為,WordPress 無法從任何層面代表當今的生態系統。
總體來說,有 2 個主要的 web 應用框架以及一些相對而言較小的框架,如 Symfony 和 Laravel。除此之後,還有 Zend、Yii、Cake、 Code Igniter 等等。
如果你想了解現代 PHP 開發究竟是什麼樣子,那麼就需要掌握 Symfony 和 Laravel 中的一個,這 2 個框架都有龐大的生態系統,包含各種包和產品。從管理面板和客戶關係管理系統 (CRM) 到單獨的包,從持續集成 (CI) 到性能監視工具,我們有無數的服務如 web 套接字伺服器、隊列管理器、支付集成等等。
但是,這些框架都是為實際開發而設計的。如果你需要純粹的內容管理,WordPress 和 CraftCMS 是理想選擇,而且它們還會不斷優化。
衡量 PHP 生態系統目前狀態的方法是看一看 Packagist,它是 PHP 主要的包倉庫。在過去的時間裡,它呈現出了指數式增長的態勢,每天 2500 萬左右的下載量,足以說明 PHP 生態系統已經不再是過去那種弱者了。
Packagist 網站上列出了過去的包和版本數量:
除了應用框架和內容管理系統 (CMS) 以外,我們還發現,在過去幾年,非同步框架也崛起了。
非同步框架是指用 PHP 或其它語言編寫的框架和伺服器,它們能夠讓用戶運行真正非同步的 PHP。非同步框架的例子包括:Swoole、Amp 和 ReactPHP。
由於我們已經進入非同步領域,具有大量 IO 的 web 套接字和應用等東西在 PHP 世界中就變得非常重要。
另外,人們還談到了內部郵件列表,在郵件列表中,PHP 核心開發者討論了 PHP 語言的進一步發展,例如增加 libuv 到核心之中。對於不熟悉 libuv 的人來說,libuv 同 Node.js 用於實現其所有非同步性的庫一模一樣。
語言本身
儘管非同步 (async) 和等待 (await) 還未面市,但 PHP 在過去幾年已經經過了許多改進,下面便是 PHP 新特性的不完全列表:
短閉包
https://stitcher.io/blog/short-closures-in-php
空合併運算符
https://stitcher.io/blog/shorthand-comparisons-in-php#null-coalescing-operator
Traits
https://www.php.net/manual/en/language.oop5.traits.php
屬性類型
https://stitcher.io/blog/new-in-php-74#typed-properties-rfc
擴散運算符
https://wiki.php.net/rfc/argument_unpacking
JIT 編譯器
https://wiki.php.net/rfc/jit
FFI
https://wiki.php.net/rfc/ffi
匿名類
https://www.php.net/manual/en/language.oop5.anonymous.php
聲明返回類型
https://www.php.net/manual/en/functions.returning-values.php#functions.returning-values.type-declaration
現代密碼學
https://wiki.php.net/rfc/libsodium
Generators
https://wiki.php.net/rfc/generators
其他
https://www.php.net/ChangeLog-7.php
儘管我們的主題是 PHP 的語言特性,但我還是覺得需要談一下 PHP 語言的開發流程。雖然社區被允許提出 RFC,但仍有一個活躍的志願者核心團隊在推動 PHP 的發展。在添加一個新的語言特性之前,必須要進行投票。只有獲得 2/3 多數選票的 RFC 才能被添加到核心中。
大約有 100 個人可以投票,但你不需要給每個 RFC 投票。核心團隊的成員毋庸置疑能夠投票,因為他們必須維護代碼庫。除了他們以外,還有一群人是單獨從 PHP 社區中挑選出來的,這些人員包括 PHP 文件的維護人員,PHP 整體項目的貢獻者,以及 PHP 社區中頗具威望的開發者。
雖然大多數核心開發是由志願者組成的,但其中一名核心 PHP 開發者 Nikita Popov 近期被 JetBrains 僱傭,並全職負責該語言的開發。另外一個例子是 Linux 基金會決定投資 Zend 框架。上述這些僱傭和收購行為確保了未來 PHP 開發的穩定性。
工 具
除了核心本身,我們還目睹了過去幾年間工具的增長。首先進入我腦海的是靜態分析器如 Vimeo 發明的 Psalm,以及 Phan 和 PHPStan。
這些工具能夠靜態分析 PHP 代碼,並且報告打字錯誤、可能的 bug 等等。在某些方面,它們提供的功能足以和 TypeScript 相媲美,但目前 PHP 還沒有被轉編譯 (transpile),因此它並不支持定製句法。
雖然這意味著我們必須依賴於文檔塊,但 PHP 的最初發明者 Rasmus Lerdorf 提出了將靜態分析引擎添加到核心之中的想法。這個想法潛力巨大,但任務量著實不小。
提到轉編譯,由於受到 JavaScript 社區的啟發,有許多人試圖將 PHP 句法延伸到用戶空間中。一個名叫 Pre 的項目就做了這件事情:它支持新的已經轉編譯為普通 PHP 代碼的 PHP 句法。
雖然這一想法已經在 JavaScript 中得以實現,但只有在提供了適當的集成開發環境 (IDE) 和靜態分析支持後,它才能在 PHP 工作。這一想法非常有趣,但還必須不斷完善,才能變成「主流」。
結束語
儘管 PHP 還有很多缺點和遺留問題,但我可以充滿信心地說,我喜歡使用它。就我的經驗來看,它可以創建可靠、可維護和高質量的軟體。如果使用得當,PHP 對於 web 開發來說是個非常棒的選擇。
英文原文
https://stitcher.io/blog/php-in-2019
彩蛋一
新浪微博是國內使用 PHP 語言的代表之一,前新浪微博首席架構師惠新宸就是 PHP 開發組的核心成員。2016 年,InfoQ 編輯約稿了新浪微博,分享了新浪微博的 PHP 7 升級實踐以及選型思路。文章年代雖然較為久遠了,但背後的思路和實踐細節依舊值得參考,感興趣的同學可以在 InfoQ 公眾號對話框回復關鍵詞:PHP,獲取文章詳情。
TAG:InfoQ |