當前位置:才華齋>計算機>php語言>

PHP語言最令人“抓狂”的十二種特性

php語言 閱讀(1.84W)

PHP語言有哪些令人抓狂的特性呢?下面小編就為大家收集了相關的內容,歡迎閱讀!

PHP語言最令人“抓狂”的十二種特性

  轉換令人頭痛

在利用PHP進行專案建立的過程中,最大的挑戰之一在於牢記我們哪些時候需要輸入HTML、而哪些時代需要輸入PHP程式碼。將二者相結合正是PHP語言的一大賣點,但要充分發揮其優勢卻著實不是易事。當我們檢視某個檔案並關注其中的程式碼時,首先需要搞清楚的就是—那些迫使我們不得不從HTML編寫轉向建立伺服器指令的標籤都在哪裡?各位必須要高度重視這些標籤,因為只有這樣我們才能將程式碼與標記整合起來並使其順暢運作。當然,大多數情況下它只會讓人暈頭轉向。

  標記的迷宮

將伺服器指令與瀏覽器標記結合起來實在是一種失誤。在Java這方面,其研發團隊嚴格遵循著MVC模式。資料模型被歸於一個檔案中,用於控制檢視的佈局結構被歸於另外的檔案中,而用於構建控制器的邏輯也擁有自己的歸屬檔案。將這些條目區分並隔離開來能夠讓整個專案變得更有條理。但在PHP方面,最基本的設計思路就是開發者應當將HTML標記與伺服器的控制器邏輯雜糅在一起。雖然我們不是沒辦法把它們區分開—大多數人也確實是這樣做的.—不過一旦開始專門處理這項任務,很多朋友可能會像我們一樣問自己“為什麼我們非要用PHP不可?”

  命名約定的不一致性與特殊性

大家知不知道我們什麼時候需要用到下劃線符號?可以看到,base64_encode方法中用到了下劃線,但urlencode則沒有。此外,php_uname這一名稱中使用了下劃線,而phpversion則沒有。為什麼會這樣?有沒有人考慮過這個問題?大家有沒有編輯過API?

與此同時,strcmp函式是不能夠大寫的,但strcasecmp卻可以。另外,strpos不能大寫,stripos則可以。到底是其中的字母“i”決定了能否大寫,還是函式整體名稱決定的?誰能記得住這麼多亂七八糟的規則?當然,開發者們必須得記清楚。

  災難般的排序

我們到底需要多少種排序函式?Java擁有一項基礎排序函式外加一個適用於所有物件的簡單介面。如果大家希望使用其它演算法、動手新增進去即可,而且大多數情況下標準函式已經完全夠用。而在PHP這邊,光是排序函式就能列出一條長長的清單:usort、sort、uksort以及array_sort等等(請注意,其中有一些還需要用到下劃線)。所以,請大家馬上把這些內容記到小本上,並祈禱自己在實際使用時不會搞混吧。

  開源存在一定侷限性

PHP也許確實擁有開源的諸多優勢,但快取等卓越功能卻只存在於商用版本當中。當然,這就是現實社會,畢竟Zend需要藉此賺取利潤。再有,該公司還需要通過向特定使用者群體出售最佳版本的方式支援整個PHP專案。抱怨這一點就像抱怨地心引力帶來的不便一樣,正確但卻毫無意義—地球就在那裡,根本不鳥你喜不喜歡。請大家活得理性一些,別總幻想著人們都能活在烏托邦式的開源環境當中。

  糟糕的名稱空間

大家有沒有建立自己函式的打算?如果有,請首先確定到底要使用PHP 5.3或者其後續版本,因為這裡正是命名空間出現的分界線。如果大家希望使用早期版本,則必須確保編碼內容與庫之間不存在衝突—畢竟在早期發展階段,PHP中的所有內容都具備全域性化屬性。如果大家決定使用PHP 5.3並接受名稱空間的加入,那麼請作好準備迎接“反斜槓”—一個醜陋的標點符號—的降臨。

  糟糕的type安全

這個問題簡直可怕,首先舉個PHP程式設計師們喜聞樂見的例子:

(string)"false"

(int)0

請注意,這並不屬於那種某些PHP支持者所爭論的“函式副作用”的典型情況。畢竟t當中也包含著大量由於type轉換所引發的同類情況。事實上,這一行

想表達的是:左側為字串,右側為一個整數。只不過左側與右側內容完全相等。照這樣說來,如果讓PHP的設計者負責管理、世界上的每個人都能彼此和睦相處。

  選擇太多,冗餘太多

PHP語言的一大特色就是可做的事太多,做事的途徑同樣太多。每一行命令的結尾都可以通過數字符號或者雙斜線來進行註釋。無論是浮點數字還是雙精度數字都代表著同樣的含義。簡單的設計往往會被人們所忽略,因為大家在程式碼貢獻過程中喜歡新增自己的小特性。這有點像依靠委員會體系進行設計,只不過該委員會從來沒考慮到過把其中的差異性剔除掉。

  詭異的變數命名規則

把美元符號作為字首實在不是個好主意。也許強制性地在所有變數前新增這個符號是為了更輕鬆地將其插入到模板當中,但這樣說來常數內容也同樣需要這麼個符號啊—為什麼實際上卻用不著呢?

  CPU資源爭奪戰

對於32位計算裝置來說,整數數值過大始終是個無法迴避的難題。不過在另一方面,64位裝置卻不會受此影響,也就是說程式碼在不同裝置上的執行狀態是不同的。大家可以在自己的筆記本上測試一下,我可以保證事實絕對是如此。但一旦把執行平臺轉換成伺服器,情況則會再度變化。這時如果大家希望重現自己桌上型電腦上的錯誤,結果恐怕要令各位失望。惟一的好訊息是,32位裝置將很可能最終消失。

  SQL注入

將SQL注入這一安全漏洞的主要形式之一歸咎於PHP確實有失公允。人們在其它語言當中同樣會不慎輸入奇怪的SQL字串。之所以將其納入文章,主要是考慮到PHP語言更容易讓該漏洞攫取資料併發送至MySQL—簡單是輕而易舉。雖然新手在使用任何一種語言時都可能犯下同樣的錯誤,但這類情況在PHP中出現的機率明顯要高得多得多。

  不相容式的變更太多太多

不同版本之間存在巨大差異,相容性問題也絕不是小事。以Java或者t為代表的程式語言在快速發展的同時也犧牲了向下相容的特性。事實上,老程式碼在新裝置上無法執行的問題並不少見。但這一切與PHP的情況其實不盡相同。在PHP方面,不同版本之間往往差別巨大,因此大家只能祈禱自己的伺服器已經安裝了正確的版本,否則只有在出現嚴重問題時才能意識到大事不妙。總而言之,在檢視伺服器上是否有專案需要升級時,請優先把目光對準PHP。