2019年,PHP已不再是當年那個“設計糟糕”的語言

之前,有一篇非常流行的博客是《PHP:那些糟糕的設計》,第一次讀到這篇博客的時候,我正在一個非常破舊的地方工作,處理着許多PHP遺留項目。這篇博客對我觸動很深,我開始思考是否要停止編程,換一份完全不同的工作。

幸運的是,很快我就換了一份工作,而PHP在5.X版本之後又有了很多新的改進。今天,我要向那些不再使用PHP編程,或者陷入遺留項目的人致敬。

劇透:直到今天,PHP仍有很多糟糕的東西,例如許多核心功能仍然存在不一致的方法簽名,仍然存在令人混淆的配置設置,仍然會有一些開發者因爲知識的缺乏而導致寫的代碼很糟糕等等。
但是,本文我想把目光集中在PHP已經改進的地方上面,以及如何寫出更加乾淨和易維護的PHP代碼。也許你不會改變對PHP的看法,但很有可能,你會吃驚於過去幾年PHP的進步。

要點:

  • PHP每年都會推出一個新的版本;
  • 自PHP 5代之後,其性能不斷提升;
  • 有框架、包和平臺組成的活躍生態系統;
  • 過去幾年間,PHP添加了許多新的特性,且現在仍在持續演進。
  • 許多工具如靜態分析器也越發成熟,未來也將繼續發展。

更新:很多人希望我能夠展示一下實際代碼,這是我其中一個業餘項目的源代碼,它是用PHP和Laravel寫的,另外還有一個是我們在辦公室負責維護的上百個OSS包的列表。

回顧歷史

讓我們先快速回顧一下PHP的版本發佈週期。現在PHP的版本是 7.3,預計2019年末將發佈PHP 7.4,7.4之後的版本將會是PHP 8.0。

從5.X版本之後,PHP核心團隊一直在努力每年發佈一個新版本,並且在過去的4年間,這一目標一直完成得很好。

大致來說,每個新版本都會用2年時間進行積極地支持,然後用一年進行“安全修補”工作。這樣做的目的是促使PHP開發者儘可能保持最新狀態,例如每年都升級比從5.4直接跳到7.0要簡單得多。

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應用框架以及一些相對而言較小的框架,如SymfonyLaravel。除此之後,還有Zend、Yii、Cake、 Code Igniter等等。

如果你想了解現代PHP開發究竟是什麼樣子,那麼就需要掌握SymfonyLaravel中的一個,這2個框架都有龐大的生態系統,包含各種包和產品。從管理面板和客戶關係管理系統(CRM)到單獨的包,從持續集成(CI)到性能監視工具,我們有無數的服務如web套接字服務器、隊列管理器、支付集成等等。

但是,這些框架都是爲實際開發而設計的。如果你需要純粹的內容管理,WordPress和CraftCMS是理想選擇,而且它們還會不斷優化。

衡量PHP生態系統目前狀態的方法是看一看Packagist,它是PHP主要的包倉庫。在過去的時間裏,它呈現出了指數式增長的態勢,每天2500萬左右的下載量,足以說明PHP生態系統已經不再是過去那種弱者了。

Packagist網站上列出了過去的包和版本數量:

除了應用框架和內容管理系統(CMS)以外,我們還發現,在過去幾年,異步框架也崛起了。

異步框架是指用PHP或其它語言編寫的框架和服務器,它們能夠讓用戶運行真正異步的PHP。異步框架的例子包括:SwooleAmpReactPHP

由於我們已經進入異步領域,具有大量IO的web套接字和應用等東西在PHP世界中就變得非常重要。

另外,人們還談到了內部郵件列表,在郵件列表中,PHP核心開發者討論了PHP語言的進一步發展,例如增加libuv到核心之中。對於不熟悉libuv的人來說,libuv同Node.js用於實現其所有異步性的庫一模一樣。

語言本身

儘管異步(async)和等待(await)還未面市,但PHP在過去幾年已經經過了許多改進,下面便是PHP新特性的不完全列表:

儘管我們的主題是PHP的語言特性,但我還是覺得需要談一下PHP語言的開發流程。雖然社區被允許提出RFC,但仍有一個活躍的志願者核心團隊在推動PHP的發展。在添加一個新的語言特性之前,必須要進行投票。只有獲得2/3多數選票的RFC才能被添加到核心中。

大約有100個人可以投票,但你不需要給每個RFC投票。核心團隊的成員毋庸置疑能夠投票,因爲他們必須維護代碼庫。除了他們以外,還有一羣人是單獨從PHP社區中挑選出來的,這些人員包括PHP文件的維護人員,PHP整體項目的貢獻者,以及PHP社區中頗具威望的開發者。

雖然大多數核心開發是由志願者組成的,但其中一名核心PHP開發者Nikita Popov近期被JetBrains僱傭,並全職負責該語言的開發。另外一個例子是Linux基金會決定投資Zend框架。上述這些僱傭和收購行爲確保了未來PHP開發的穩定性。

工具

除了核心本身,我們還目睹了過去幾年間工具的增長。首先進入我腦海的是靜態分析器如Vimeo發明的Psalm,以及PhanPHPStan

這些工具能夠靜態分析PHP代碼,並且報告打字錯誤、可能的bug等等。在某些方面,它們提供的功能足以和TypeScript相媲美,但目前PHP還沒有被轉編譯(transpile),因此它並不支持定製句法。

雖然這意味着我們必須依賴於文檔塊,但PHP的最初發明者Rasmus Lerdorf提出了將靜態分析引擎添加到核心之中的想法。這個想法潛力巨大,但任務量着實不小。

提到轉編譯,由於受到JavaScript社區的啓發,有許多人試圖將PHP句法延伸到用戶空間中。一個名叫Pre的項目就做了這件事情:它支持新的已經轉編譯爲普通PHP代碼的PHP句法。

雖然這一想法已經在JavaScript中得以實現,但只有在提供了適當的集成開發環境(IDE)和靜態分析支持後,它才能在PHP工作。這一想法非常有趣,但還必須不斷完善,才能變成“主流”。

小結

儘管PHP還有很多缺點和遺留問題,但我可以充滿信心地說,我喜歡使用它。就我的經驗來看,它可以創建可靠、可維護和高質量的軟件。如果使用得當,PHP對於web開發來說是個非常棒的選擇。

查看英文原文:PHP in 2019

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章