PHP 對(duì)程序員的要求更高
當(dāng)前位置:點(diǎn)晴教程→知識(shí)管理交流
→『 技術(shù)文檔交流 』
首先, 大家都知道, PHP也是一種編譯型腳本語(yǔ)言, 和其他的預(yù)編譯型語(yǔ)言不同, 它不是編譯成中間代碼, 然后發(fā)布.. 而是每次運(yùn)行都需要編譯.. 為此, 也就有了一些Opcode Cacche, 比如開源的APC, eacc. 還有商業(yè)的Zend O+等. 那么為什么PHP不把編譯/執(zhí)行分開呢? PHP雖然是一種編譯型腳本語(yǔ)言, 但是它的編譯速度非??? 它的編譯不做任何優(yōu)化, 就是簡(jiǎn)單的忠實(shí)的把你所寫的代碼翻譯成對(duì)應(yīng)的Opcodes. 而其他語(yǔ)言因?yàn)樵诰幾g器做很多的優(yōu)化工作, 會(huì)造成編譯比較重, 也一定程度上要求它們分離. 所以, 理論上來說, 通過編譯執(zhí)行分離, 想達(dá)到源碼加密, 是不會(huì)有什么太大收效的, 因?yàn)樗苋菀妆环较? 另外, 編譯直接分離, 并不會(huì)帶來特別大的收益, 反而會(huì)降低調(diào)試部署的效率(想想, 修改, 編譯, 發(fā)布, 看效果), 并且APC等優(yōu)化工具, 已經(jīng)很成熟了.. 到這里, 請(qǐng)大家注意這句:”它的編譯不做任何優(yōu)化”…. 這也就是我為什么說, PHP對(duì)程序員的要求更高, 不同于其他的編譯型語(yǔ)言, PHP在編譯的時(shí)候不會(huì)幫你做一些優(yōu)化, 比如對(duì)于如下的代碼: for ($i=0;$i$i<strlen($j);$i++) { 如果對(duì)于C或者Java等其他語(yǔ)言, 它也許會(huì)幫你做優(yōu)化, 把strlen提取到前面去, 只做一次就夠了. 而對(duì)于PHP來說, 它在編譯的時(shí)候不做任何優(yōu)化, 也就是說, 你的strlen, 會(huì)被調(diào)用很多次. 再比如: $table = "table"; while(++$i < 1000) { $sql = "select * from" . $table . "where id = " . $i; } 沒錯(cuò), “select * from ” . $table會(huì)被concat 1000次.. 可見, PHP的程序員, 需要認(rèn)真的想好, 你的代碼會(huì)怎么被執(zhí)行, 你怎么寫代碼, 最終的執(zhí)行效率才最高. 而不像其他的語(yǔ)言, 程序員可以把一部分優(yōu)化工作交給編譯器. 這也就是我為什么說:”PHP對(duì)程序員的要求更高” 的原因. 該文章在 2012/4/3 13:21:08 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |