當然這種方式并沒有錯誤,只不過在效率上它比下面的方式要稍稍差些:

復制代碼 代碼如下: include(realpath(dirname(_FILE_)).DIRECTORY_SEPARATOR.'inclu " /> 黄色肉肉视频,黄色观看,青青青国产依人在线视频97

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php中inlcude()性能對比詳解

include性能
復制代碼 代碼如下:
include('include.php');


當然這種方式并沒有錯誤,只不過在效率上它比下面的方式要稍稍差些:

復制代碼 代碼如下:
include(realpath(dirname(_FILE_)).DIRECTORY_SEPARATOR.'include.php');


這種方式我們可能需要輸入更多一些,但相對于前面那種需要php引擎去include_path 中迭代查找所有名稱為'include.php'才能查找到相應對象來說,dirname(__FILE__)這種絕對路徑的指定會讓系統迅速定位到相應文件。

php中常量__FILE__ 其實跟C#中的AppDomain.CurrentDomain.BaseDirectory非常類似,它返回的是當前代碼正在執行的代碼所在文件的絕對路徑。而函數dirname()則返回其父文件夾路徑。
另外一個更查找效率高,并且書寫簡單的方式是include('./include.php'),這相當于告訴系統查找當前路徑下的'include.php'文件。

在大型系統中我們常常使用另外一個更好的方式,我們常常在路由文件或其他初始化文件中加入如下代碼:

復制代碼 代碼如下:
define('APP_PATH',realpath(dirname(_FILE_)));

這相當于給系統添加了一個全局變量來指出系統根目錄,當我們后面需要引用某具體路徑下的文件時我們就可以使用如下代碼了:
復制代碼 代碼如下:
include(APP_PATH.DIRECTORY_SEPARATOR.'models'.'User.php');


autoload與include性能比較

例如有以下四個腳本:

復制代碼 代碼如下:
#file:include1.php
include 'include2.php';
//@todo something#file:include2.php
//@todo something#file:script1.php
include 'include2.php';
//@todo something
#file:script2.php
include 'include1.php';
include 'script1.php'
//@todo something

當執行script1.php時, include ‘include2.php'; 這行代碼被執行了一次。而執行script2.php時,這行代碼被執行了兩次。
這里只是一個簡單的例子,在實際的項目中,include2.php被include的次數可能更多。這樣反復的include,是否會影響性能呢?為此我寫了個腳本來測試。

復制代碼 代碼如下:
#file:SimpleClass.php
class SimpleClass {
public function __construct() {
echo get_time() . "rn";
}
}
#file:php_include.php
for($i = 0;$i < $loop;$i++) {
include_once "SimpleClass.php";
new SimpleClass();
}


當$loop值為1時,腳本耗時約0.00018906593322754秒,當$loop為1000時,腳本耗時約0.076701879501343秒。

如果我們用autoload實現呢?

復制代碼 代碼如下:
#file:php_autoload.php
function __autoload($class_name) {
include_once $class_name . '.php';
}for($i = 0;$i < $loop;$i++) {
new SimpleClass();
}

在這段代碼中,我定義了__autoload函數,幾乎一樣的腳本,當$loop為1時,耗時0.0002131462097168秒,而當$loop為1000時,耗時僅為前面代碼的1/7,0.012391805648804秒。
但請注意看SimpleClass的代碼,其中輸出了一行字符串,如果去掉這行輸出后再比較,會是什么樣的結果呢?

在$loop同為1000的情況下,前者耗時0.057836055755615秒,而使用了autoload后,僅僅0.00199294090271秒!效率相差近30倍!

從上面的測試可以看出,當文件僅僅被include一次,autoload會消耗稍微多一點的時間,但如果在文件被反復include的情況下,使用autoload則能大大提高系統性能。
至于是否要使用autoload來解放程序員,這就仁者見仁,智者見智了。在我看來,條件允許的前提下,犧牲這一點性能(某些情況下,甚至可能是提升性能)更為便捷的開發,是值得的。

include()和require()性能

對include()來說,在 include()執行時文件每次都要進行讀取和評估;
而對于require()來說,文件只處理一次(實際上,文件內容替換了require()語句)。
這就意味著如果有包含這些指令之一的代碼和可能執行多次的代碼,則使用require()效率比較高。
另一方面,如果每次執行代碼時相讀取不同的文件,或者有通過一組文件疊代的循環,就使用include(),
因為可以給想要包括的文件名設置一個變量,當參數為include()時使用這個變量。

php技術php中inlcude()性能對比詳解,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久免费区一区二区三波多野 | 在线观看黄网视频免费播放 | 免费国产h视频在线观看 | chinese在线播放91国内 | 国产精品二区页在线播放 | 国产极品美女在线 | 久久久久亚洲精品影视 | 色噜噜国产在线91蝌蚪 | 国产精品大全国产精品 | 亚洲综合色色图 | 狠狠色噜噜狠狠狠狠奇米777 | 色天天躁夜夜躁天干天干 | 精品国产亚一区二区三区 | 国产精品久久久久毛片真精品 | 国产精品午夜久久 | 久久国产偷 | 久久这里精品青草免费 | 成年美女黄网站色大片软件 | 国产黄色片在线播放 | 一级做a爰片性色毛片小说 一级做a爰片性色毛片新版的 | 亚洲一区精品伊人久久 | 日本成人在线网站 | 久久综合偷拍 | 久久国内精品自在自线观看 | 99视频在线观看视频一区 | 亚洲精品第一国产综合高清 | 四虎影视永久在线 yin56xyz | 玖玖操| 成人精品亚洲 | 国内精品手机在线观看视频 | 一区二区三区视频免费 | 五月婷婷丁香综合 | 欧美一级日韩一级亚洲一级 | 欧美日一区二区三区 | 婷婷六月久久综合丁香可观看 | 欧洲精品一区二区三区在线观看 | 最色网在线观看 | 国产综合自拍 | 91在线短视频 | 欧美夜色 | 伊人久久青青 |