| 導購 | 订阅 | 在线投稿
分享
 
 
 

評論:PHP程序不適用大型系統的九大原因

來源:互聯網網民  2008-06-12 07:23:45  評論

PHP確實十分容易編寫。但是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、沒有命名空間

設想某個人制作了一個PHP模塊用來閱讀文件。模塊中一個函數叫做read。然後另一個人的模塊可以讀取網頁的,同樣包含一個函數read。然後我們就無法同時使用這兩個模塊了,因爲PHP不知道你要用哪個函數。但是有一個很簡單的解決方法,那就是命名空間。曾經有人建議PHP5加入這個特性,但不幸的是他沒有這麽做。現在,沒有命名空間,每個函數都必須加上模塊名作爲前綴,來避免名稱沖突。這導致了函數名恐怖得長,例如xsl_xsltprocessor_transform_to_XML讓代碼難于書寫和理解。

5、不標准的日期格式字符

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

6、混亂的許可證

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

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

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

直接拼接:getnumberoffiles

用下劃線分開:get_number_of_files

駱駝法則:getNumberOfFiles

大部分語言選擇其中一中。但是PHP都用到了。

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

8、魔法引用的地獄

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

9、缺少標准框架

一個成長中的網站沒有一個整體框架,最終會變成維護的噩夢。一個框架可以讓很多工作變得簡單。現在最流行的框架模型時MVC-模型,在其中表現層、業務邏輯和數據庫訪問都分離開了。

很多PHP網站不使用MVC-模型。他們甚至沒有一個框架。甚至現在有一些PHP框架同時你都可以自己寫一個,關于PHP的文章和手冊沒有提高框架的一個字。同時JSP-開發人員使用像Struts的框架、ASP開發人員使用.net,看起來好像這些概念都廣泛被PHP開發人員所了解。這就說明了PHP實際上到底是多專業。

總結

什麽問題?

對于非常小的項目,它可以是一個十分符合人意的編程語言。但是對于較大的和更爲複雜的項目,PHP就顯出他的薄弱了。當你不斷地摸索之後,你會發現我提到的某些問題的解決方案。所以,當解決方案已知之後,爲什麽不能修正他呢?另外,爲什麽這些修補不在手冊中提到呢? 一個開源的語言十分流行是一件好事。但不幸得是,它不是一個偉大的語言。我希望所有的問題能有一天得到解決(也許在PHP6),然後,我們就將擁有一個開源語言,他既開源,又好用。

到現在,當你要啓動一個多于5個腳本頁面的項目的時候,你最好考慮C#/ASP.NET或者 Java/JSP或者也許Python同樣是一個更好的選擇。

 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
PHP確實十分容易編寫。但是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、沒有命名空間 設想某個人制作了一個PHP模塊用來閱讀文件。模塊中一個函數叫做read。然後另一個人的模塊可以讀取網頁的,同樣包含一個函數read。然後我們就無法同時使用這兩個模塊了,因爲PHP不知道你要用哪個函數。但是有一個很簡單的解決方法,那就是命名空間。曾經有人建議PHP5加入這個特性,但不幸的是他沒有這麽做。現在,沒有命名空間,每個函數都必須加上模塊名作爲前綴,來避免名稱沖突。這導致了函數名恐怖得長,例如xsl_xsltprocessor_transform_to_XML讓代碼難于書寫和理解。 5、不標准的日期格式字符 很多程序員對 日期格式字符 都很熟悉,它是從UNIX和C語言中來的。其他一些編程語言采用了這個標准,但是很奇怪的,PHP有它自己的一套完全不兼容的日期格式字符。在C中,「%j」表示一年中的當天,在PHP中他表示一個月中的當天。然而使事情更混亂的是:Smarty (一個很流行的PHP模版引擎)的 strftime 函數和 date_format 函數,卻使用了C/UNIX的格式化字符。 6、混亂的許可證 你也許認爲PHP是免費的,所有的在手冊中提到的PHP模塊也是免費的。錯了!例如,如果你想在PHP中生成PDF文件,你會在手冊中發現兩個模塊:PDF 和 ClibPDF。但是這兩個都是有商業許可證的。所以,你所使用的每個模塊,你都要確保你同意他的許可證。 7、不一致的函數命名規則 有些函數名稱是有多個單詞組成的。一般有三種單詞組合的習慣: 直接拼接:getnumberoffiles 用下劃線分開:get_number_of_files 駱駝法則:getNumberOfFiles 大部分語言選擇其中一中。但是PHP都用到了。 例如,你想要把一些特殊字符轉換成HTML實體,你會使用函數htmlentities (直接拼接單詞)。如果你要使用相反的功能,你要用到它的小弟html_entity_decode。由于某些特殊的原因,這個函數名是由下劃線分隔單詞。怎麽能這樣呢?你知道有一個函數叫strpad。或者他是str_pad?每次你都要查看一下到底這個符號是什麽或者直接等他出現一個錯誤。函數是不分大小寫的,所以對于PHP來說rawurldecode 和RawUrlDecode之間沒有什麽區別。這也很糟糕,因爲兩個都使用到了同時他們看上去還不一樣,混淆了閱讀者。 8、魔法引用的地獄 魔法引用(Magic quote)可以保護PHP腳本免受SQL注入攻擊。這很好。但是出于某些原因,你可以在php.ini中關閉這個配置。所以你如果要寫出一個有彈性的腳本,你總要檢查魔法引用是開啓還是關閉。這樣一個「特性」應該讓編程更簡單,而事實上變得更複雜了。 9、缺少標准框架 一個成長中的網站沒有一個整體框架,最終會變成維護的噩夢。一個框架可以讓很多工作變得簡單。現在最流行的框架模型時MVC-模型,在其中表現層、業務邏輯和數據庫訪問都分離開了。 很多PHP網站不使用MVC-模型。他們甚至沒有一個框架。甚至現在有一些PHP框架同時你都可以自己寫一個,關于PHP的文章和手冊沒有提高框架的一個字。同時JSP-開發人員使用像Struts的框架、ASP開發人員使用.net,看起來好像這些概念都廣泛被PHP開發人員所了解。這就說明了PHP實際上到底是多專業。 總結 什麽問題? 對于非常小的項目,它可以是一個十分符合人意的編程語言。但是對于較大的和更爲複雜的項目,PHP就顯出他的薄弱了。當你不斷地摸索之後,你會發現我提到的某些問題的解決方案。所以,當解決方案已知之後,爲什麽不能修正他呢?另外,爲什麽這些修補不在手冊中提到呢? 一個開源的語言十分流行是一件好事。但不幸得是,它不是一個偉大的語言。我希望所有的問題能有一天得到解決(也許在PHP6),然後,我們就將擁有一個開源語言,他既開源,又好用。 到現在,當你要啓動一個多于5個腳本頁面的項目的時候,你最好考慮C#/ASP.NET或者 Java/JSP或者也許Python同樣是一個更好的選擇。
󰈣󰈤
王朝萬家燈火計劃
期待原創作者加盟
 
 
 
>>返回首頁<<
 
 
 
 
 
 熱帖排行
 
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有