首頁 >後端開發 >PHP問題 >php為什麼不適合做大型專案?

php為什麼不適合做大型專案?

青灯夜游
青灯夜游原創
2019-10-12 14:48:445252瀏覽

php為什麼不適合做大型專案?

php為什麼不適合做大型專案?

1、對遞迴的不良支援

#遞迴是一種函式呼叫自身的機制。這是一個強大的特性可以把某些複雜的東西變得很簡單。有一個使用遞歸的例子是快速排序(quicksort)。不幸的是,PHP並不擅長遞迴。 Zeev,一個PHP開發人員,說:“PHP 4.0(Zend)對密集數據使用了堆疊方式,而不是使用堆方式。也就是說它能容忍的遞歸函數的數量限制和其他語言比起來明顯少。”見bug 1901。這是一個很不好的藉口。每一個程式語言都應該提供良好的遞歸支援。

2、許多PHP模組都不是線程安全的

在幾年前,Apache發布了Web伺服器的2.0版。這個版本支援多執行緒模式,在這個模式下,軟體一個一部分可以同時運行多個。 PHP的發明者說PHP的核心是線程安全的,但是非核心模組不一定是。但十次有九次,你想要在PHP腳本中使用這個模組,但這又讓你的腳本無法適合Apache的多執行緒模式。這也是為什麼PHP小組不建議在Apache 2 的多執行緒模式下執行PHP。不良的多執行緒模式支援使PHP常被認為是Apache 2仍然不流行的原因之一。

3、PHP 由於商業原因而不健全

透過使用緩存,PHP的效能可以陡增500%[見基準測試]。那為什麼快取沒有被建構在PHP中呢?因為Zend——PHP的製造者,它在銷售自己的Zend Accelerator,所以當然,他們不想拋棄自己的商業產品這塊肥肉。

但有另一個可選擇的: APC.(Zend後來推出Zend Optimizer,免費的加速器-譯者)

4、不標準的日期格式字元

很多程式設計師對日期格式字元都很熟悉,它是從UNIX和C語言來的。其他一些程式語言採用了這個標準,但是很奇怪的,PHP有它自己的一套完全不相容的日期格式字元。在C中,「%j」表示一年中的當天,在PHP中他表示一個月中的當天。然而讓事情更混亂的是:Smarty (一個很流行的PHP模版引擎)的 strftime 函數和 date_format 函數,卻使用了C/UNIX的格式化字元。

5、混亂的許可證

你也許認為PHP是免費的,所有的在手冊中提到的PHP模組也是免費的。錯了!例如,如果你想在PHP中產生PDF文件,你會在手冊中發現兩個模組:PDF 和 ClibPDF。但是這兩個都是有商業許可證的。所以,你所使用的每個模組,你都要確保你同意他的許可證。

6、不一致的函數命名規則

有些函數名稱是有多個單字組成的。一般有三種字組合的習慣:

● 直接拼接:getnumberoffiles

#● 用下劃線分開:get_number_of_files

#● 駱駝法則: getNumberOfFiles

##● 駱駝法則: getNumberOfFiles

##2語言選擇其中一。但是PHP都用到了。 例如,你想要把一些特殊字元轉換成HTML實體,你會使用函數htmlentities (直接拼接單字)。如果你要使用相反的功能,你要用到它的小弟弟html_entity_decode。由於某些特殊的原因,這個函數名稱是由底線分隔單字。怎麼能這樣呢?你知道有一個函數叫strpad。還是他是str_pad?每次你都要查看一下到底這個符號是什麼或直接等他出現一個錯誤。函數是不分大小寫的,所以對於PHP來說rawurldecode 和RawUrlDecode之間沒有什麼差別。這也很糟糕,因為兩個都使用到了同時他們看起來還不一樣,混淆了閱讀者。

7、魔法引用的地獄

魔法引用(Magic quote)可以保護PHP腳本免受SQL注入攻擊。這很好。但是出於某些原因,你可以在php.ini中關閉這個配置。所以你如果要寫出一個有彈性的腳本,你總是要檢查魔法引用是開啟還是關閉。這樣一個「特性」應該會讓程式設計更簡單,而事實上變得更複雜了。

總結

對於非常小的項目,它可以是十分符合人意的程式語言。但是對於較大的和更複雜的項目,PHP就顯出他的薄弱了。

###更多PHP相關知識,請造訪###PHP中文網###! ###

以上是php為什麼不適合做大型專案?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn