您好,登錄后才能下訂單哦!
做大型項(xiàng)目時(shí)php為什么不適合?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
1、對(duì)遞歸的不良支持
遞歸是一種函數(shù)調(diào)用自身的機(jī)制。這是一種強(qiáng)大的特性可以把某些復(fù)雜的東西變得很簡(jiǎn)單。有一個(gè)使用遞歸的例子是快速排序(quicksort)。不幸的是,PHP并不擅長(zhǎng)遞歸。Zeev,一個(gè)PHP開(kāi)發(fā)人員,說(shuō)道:“PHP 4.0(Zend)對(duì)密集數(shù)據(jù)使用了棧方式,而不是使用堆方式。也就是說(shuō)它能容忍的遞歸函數(shù)的數(shù)量限制和其他語(yǔ)言比起來(lái)明顯少?!币?jiàn)bug 1901。這是一個(gè)很不好的借口。每一個(gè)編程語(yǔ)言都應(yīng)該提供良好的遞歸支持。
2、許多PHP模塊都不是線(xiàn)程安全的
在幾年前,Apache發(fā)布了Web服務(wù)器的2.0版。這個(gè)版本支持多線(xiàn)程模式,在這個(gè)模式下,軟件一個(gè)一部分可以同時(shí)運(yùn)行多個(gè)。PHP的發(fā)明者說(shuō)PHP的核心是線(xiàn)程安全的,但是非核心模塊不一定是。但是十次有九次,你想要在PHP腳本中使用這種模塊,但這又使你的腳本不能合適Apache的多線(xiàn)程模式。這也是為什么PHP小組不推薦在Apache 2 的多線(xiàn)程模式下運(yùn)行PHP。不良的多線(xiàn)程模式支持使PHP常被認(rèn)為是Apache 2依然不流行的原因之一。
3、PHP 由于商業(yè)原因而不健全
通過(guò)使用緩存,PHP的性能可以陡增500%[見(jiàn)基準(zhǔn)測(cè)試]。那么為什么緩存沒(méi)有被構(gòu)建在PHP中呢?因?yàn)閆end——PHP的制造者,它在銷(xiāo)售自己的Zend Accelerator,所以當(dāng)然,他們不想拋棄自己的商業(yè)產(chǎn)品這塊肥肉。
但是有另一個(gè)可選擇的: APC. (Zend后來(lái)推出Zend Optimizer,免費(fèi)的加速器——譯者)
4、不標(biāo)準(zhǔn)的日期格式字符
很多程序員對(duì)日期格式字符都很熟悉,它是從UNIX和C語(yǔ)言中來(lái)的。其他一些編程語(yǔ)言采用了這個(gè)標(biāo)準(zhǔn),但是很奇怪的,PHP有它自己的一套完全不兼容的日期格式字符。在C中,“%j”表示一年中的當(dāng)天,在PHP中他表示一個(gè)月中的當(dāng)天。然而使事情更混亂的是:Smarty (一個(gè)很流行的PHP模版引擎)的 strftime 函數(shù)和 date_format 函數(shù),卻使用了C/UNIX的格式化字符。
5、混亂的許可證
你也許認(rèn)為PHP是免費(fèi)的,所有的在手冊(cè)中提到的PHP模塊也是免費(fèi)的。錯(cuò)了!例如,如果你想在PHP中生成PDF文件,你會(huì)在手冊(cè)中發(fā)現(xiàn)兩個(gè)模塊:PDF 和 ClibPDF。但是這兩個(gè)都是有商業(yè)許可證的。所以,你所使用的每個(gè)模塊,你都要確保你同意他的許可證。
6、不一致的函數(shù)命名規(guī)則
有些函數(shù)名稱(chēng)是有多個(gè)單詞組成的。一般有三種單詞組合的習(xí)慣:
● 直接拼接:getnumberoffiles
● 用下劃線(xiàn)分開(kāi):get_number_of_files
● 駱駝法則:getNumberOfFiles
大部分語(yǔ)言選擇其中一中。但是PHP都用到了。
例如,你想要把一些特殊字符轉(zhuǎn)換成HTML實(shí)體,你會(huì)使用函數(shù)htmlentities (直接拼接單詞)。如果你要使用相反的功能,你要用到它的小弟弟html_entity_decode。由于某些特殊的原因,這個(gè)函數(shù)名是由下劃線(xiàn)分隔單詞。怎么能這樣呢?你知道有一個(gè)函數(shù)叫strpad?;蛘咚莝tr_pad?每次你都要查看一下到底這個(gè)符號(hào)是什么或者直接等他出現(xiàn)一個(gè)錯(cuò)誤。函數(shù)是不分大小寫(xiě)的,所以對(duì)于PHP來(lái)說(shuō)rawurldecode 和RawUrlDecode之間沒(méi)有什么區(qū)別。這也很糟糕,因?yàn)閮蓚€(gè)都使用到了同時(shí)他們看上去還不一樣,混淆了閱讀者。
7、魔法引用的地獄
魔法引用(Magic quote)可以保護(hù)PHP腳本免受SQL注入攻擊。這很好。但是出于某些原因,你可以在php.ini中關(guān)閉這個(gè)配置。所以你如果要寫(xiě)出一個(gè)有彈性的腳本,你總要檢查魔法引用是開(kāi)啟還是關(guān)閉。這樣一個(gè)“特性”應(yīng)該讓編程更簡(jiǎn)單,而事實(shí)上變得更復(fù)雜了。
總結(jié)
對(duì)于非常小的項(xiàng)目,它可以是一個(gè)十分符合人意的編程語(yǔ)言。但是對(duì)于較大的和更為復(fù)雜的項(xiàng)目,PHP就顯出他的薄弱了。
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。