• <kbd id="qyk40"></kbd>
  • <strike id="qyk40"></strike><samp id="qyk40"><pre id="qyk40"></pre></samp>
    作為在那個時期出現(xiàn)的新的Web開發(fā)者,事情顯的很明白而且水到渠成:Perl已經(jīng)不適應(yīng)新的應(yīng)用開發(fā)環(huán)境了。在Perl里,頁面需要冗長的公式化的CGI方式實現(xiàn),而這些在PHP里卻可以用基本的、缺省的編程方式實現(xiàn)。Perl語言里到處都是舊時代的特征 — 引用,不方便的數(shù)據(jù)結(jié)構(gòu),還有其他許多的小的古怪語法語義 —— 這使得Web開發(fā)冗長,不穩(wěn)定,不方便。無怪乎沒有一個出色的Web應(yīng)用是用Perl寫成的,而用PHP你卻能做的又快又簡單,盡管PHP存在著在當時就顯而易見的缺陷。

    在1999年支持Perl反對PHP的爭論有很多:Perl要快的多,有更多的程序庫和驅(qū)動支持,CPAN是個神奇的地方,里面預(yù)先寫好的代碼能讓你絕大部分任務(wù)省去80%的工作量。現(xiàn)在看起來這些就有點可笑了,但“PHP缺乏可擴展性”卻是個真正的缺點。但總之PHP贏了,因為上面所說的這些問題并不是這種語言固有的。PHP解釋器可以變得更快,程序庫可以被開發(fā)出來,PERA和PECL目前已經(jīng)變得相當龐大,這還不包括各種廠商希望人們?nèi)ナ褂盟麄兊腁PI而提供的非正式的程序庫。

    時間在推移

    十年之后,我可以感覺到歷史大潮正在重演。開發(fā)人員對語言的期望在前進。如果說Perl最缺乏的是PHP里令人驚訝的靈活的“關(guān)聯(lián)數(shù)組”(也就是智能哈希表),那么PHP現(xiàn)在缺乏的就是lambdas和方法鏈(method chaining)了。同時PHP往往是用在只要20行代碼就能寫出一個網(wǎng)頁的地方,而如今卻是如果你不使用什么MVC框架之類的東西就會被認為沒有把事情做對。公式化的代碼表明了問題所在:這種語言需要一個框架來替人們做這些事情。

    退回到以前,我認為那些頑固的使用Perl來做Web開發(fā)的人很傻。現(xiàn)在,經(jīng)歷了十年的PHP開發(fā),我處在相同的位置上了。我可以在一個小時里用PHP敲出一個不錯的網(wǎng)站,在一兩天里開發(fā)出一個優(yōu)秀的網(wǎng)站。PHP的性能眾人皆知,我可以無限的擴展它。我雇傭過的每個開發(fā)人員都會它,我集成過的每個系統(tǒng)里都有一個用它寫出的打包的代碼庫。我深陷于PHP的方便性,盡管它對于我的任務(wù)并不是一個合適的語言。

    轉(zhuǎn)向Ruby on Rails

    最明顯有潛在能力繼任PHP的是Ruby on Rails。Ruby是一個新的、干凈的語言,具有現(xiàn)代的語言特征,松散、優(yōu)雅的語法(很像Python)。Rails省去了我們常見的任務(wù),省去了集成Web應(yīng)用里的公式化的做法,把PHP里三、四行的習慣寫法變成了first-class語言結(jié)構(gòu)。這看起來極其像我需要的PHP替代品、能讓開發(fā)工作再一次提速的東西。

    我每天使用Rails,修改一個喜愛這種框架和語言的有經(jīng)驗的Rails專家所寫的Rails應(yīng)用,七個月后,我卻不能斷言Rails是一個正確的選擇了,原因很難表達。我這篇文章的目的就是想試圖把原因說清楚。

    我的主要的抱怨,必須要提的,就是性能。之前就說過這種問題不應(yīng)該被當作一種語言的致命缺陷,它只是語言實現(xiàn)中的暫時的問題。所以我不能把這當作一個真正的問題,盡管它是我把現(xiàn)在的應(yīng)用移植到PHP的最主要的一個原因。我可以讓Rails跑的跟PHP一樣快,但那需要提供2到4倍高的硬件條件。我估計五年內(nèi)將還會這樣,五年后我也許不必把程序移植到PHP。但現(xiàn)在,它不能滿足我的要求。

    第二,我討厭Active Record。Active Record是一種模式,并不是Ruby固有的,在Rails的最新版本里是可選擇的,但是對它的使用和這種模式已經(jīng)深入到了Rails的DNA里了。我之前曾解釋過為什么我認為這數(shù)據(jù)庫上的ORM不是個好做法,所以我不會再重復解釋,但有一點我需要總結(jié)的就是你省去了手工寫CRUD所獲得的效能要大于ActiveRecord做傻事所損失的效能,要花時間搞清楚它是怎么工作的,順應(yīng)框架原則,防止它做這樣的事情。

    第三,我十分的不信任代碼自動生成。工具能幫你生成模板式的代碼很有用,但你的程序了卻多出了成堆的毫無用處的代碼來實現(xiàn)這些目的,這就變的不好了。代碼生成喜歡“神奇推理”,因為生成器并不確定代碼某些特別有用的特征究竟是專門寫出的還是語言環(huán)境固有自帶的。神奇推理是危險的。

    代碼生成讓我想到了Ruby on Rails的一個可能是最根本的問題,就是它并不是一種語言。Ruby是一種語言。但Ruby,它在解決了PHP上的一些基本問題外,并沒有解決核心問題,那就是現(xiàn)代Web應(yīng)用需要一系列的改進:像routing,model/view分類,drop-in功能性等都是很常見的特征。Rails里有,但這跟PHP里的Zend,Symfony 和 Code Igniter之類的MVC框架一樣只是綁上去的繃帶。

    那么缺的是什么?

    能夠取代PHP的語言必須十分優(yōu)秀于PHP,就如同PHP優(yōu)秀于Perl一樣。它必須承擔起Web應(yīng)用的主要實現(xiàn)任務(wù),就像PHP那樣,你的代碼的主要功能就是輸出網(wǎng)頁 —— 一個有點激進的要求,它要不適合去做其它的事情,例如當中shell腳本語言。我希望有這樣一種語言,它能夠承擔起我開發(fā)一個MVC式的Web應(yīng)用時的所有的任務(wù),所有功能都是核心內(nèi)置的,不能僅是一個程序包。

    問題是,沒有這樣的一種語言。有一段時間服務(wù)器端JavaScript看起來將會成為下一個重要的語言,它能統(tǒng)一Web應(yīng)用前端和后端的編程語言。但是這些JavaScript上的偉大思想總是徘徊在一些跑題的行為上,比如nodejs:事件驅(qū)動模式非常的激進和強大,能讓你開發(fā)出高性能的應(yīng)用程序,最大化的使用新式硬件,但這是一種開發(fā)服務(wù)器端應(yīng)用程序的思路,不是Web頁面。并且你仍然需要去寫一大堆可怕的Web頁面。另外一些CommonJS的成果例如ejScript開始嘗試著取代PHP,但仍沒有解決框架問題。

    仍在等待

    不得不做出結(jié)論是,PHP的替代者還不存在。Ruby on Rails很好,但并不比一個PHP之上的類似的MVC框架強多少,更別提由于Ruby自身的效率不高和ActiveRecord的ORM惡搞帶來的雙重打擊。Python看起來并不感興趣于作為下一代的Web語言,JavaScript的服務(wù)器端解決方案還剛剛只是個開始。

    穩(wěn)定

    產(chǎn)品高可用性高并發(fā)

    貼心

    項目群及時溝通

    專業(yè)

    產(chǎn)品經(jīng)理1v1支持

    快速

    MVP模式小步快跑

    承諾

    我們選擇聲譽

    堅持

    10年專注高端品質(zhì)開發(fā)
    • 返回頂部
    精品国产一区二区三区色欲| 国产精品影音先锋| 国产综合色香蕉精品五月婷| 国产精品第一区第27页| 国产 精品 自在 线| 99久久国产宗和精品1上映| 日韩精品国产一区| 久久国产精品久久精| 亚洲日韩一区二区三区| 精品人妻无码区在线视频| 人妻精品久久久久中文字幕69| 色精品一区二区三区| 中文精品一卡2卡3卡4卡| 亚洲精品美女视频| 国产一区二区精品久久凹凸| 国产成人综合久久精品下载| 竹菊影视国产精品| 日韩人妻无码精品久久免费一| 国内精品91最新在线观看| 亚洲国产日韩在线人成下载| 国产精品十八禁在线观看| 91精品国产91久久久久久最新| 国产精品免费久久久久影院 | 2022国产精品自在线拍国产| 日韩精品视频在线观看免费| 精品人妻中文av一区二区三区 | 久久精品国产99国产精品导航| 99热这里只有精品国产动漫| 国产三级精品三级在线观看| 亚洲AV永久无码精品一区二区国产| 日韩国产成人资源精品视频| 国产精品久久久久一区二区三区 | 成人三级精品视频在线观看| 国产精品久久久天天影视| 精品日产一区二区三区手机| 国内精品国语自产拍在线观看 | 国产精品亚洲片在线观看不卡 | 精品国产一区二区三区香蕉事| 自怕偷自怕亚洲精品| 正在播放国产精品放孕妇| 国产精品一久久香蕉产线看|