|
最經(jīng)常使用的就是這種方法,根據(jù)類名,找出類文件,然后require_one
復(fù)制代碼 代碼如下:
function __autoload($class_name) {
$path = str_replace('_', '/', $class_name);
require_once $path . '.php';
}
// 這里會自動加載Http/File/Interface.php 文件
$a = new Http_File_Interface();
這種方法的好處就是簡單易使用。當(dāng)然也有缺點(diǎn),缺點(diǎn)就是將類名和文件路徑強(qiáng)制做了約定,當(dāng)修改文件結(jié)構(gòu)的時候,就勢必要修改類名。
__autoload的使用方法2(直接映射法)
復(fù)制代碼 代碼如下:
$map = array(
'Http_File_Interface' => 'C:/php/HTTP/FILE/Interface.php'
);
function __autoload($class_name) {
if (isset($map[$class_name])) {
require_once $map[$class_name];
}
}
// 這里會自動加載C:/php/HTTP/FILE/Interface.php 文件
$a = new Http_File_Interface();
這種方法的好處就是類名和文件路徑只是用一個映射來維護(hù),所以當(dāng)文件結(jié)構(gòu)改變的時候,不需要修改類名,只需要將映射中對應(yīng)的項(xiàng)修改就好了。
這種方法相較于前面的方法缺點(diǎn)是當(dāng)文件多了的時候這個映射維護(hù)起來非常麻煩,或許這時候你就會考慮使用json或者單獨(dú)一個文件來進(jìn)行維護(hù)了。或許你會想到使用一個框架來維護(hù)或者建立這么一個映射。
spl_autoload
__autoload的最大缺陷是無法有多個autoload方法
好了, 想下下面的這個情景,你的項(xiàng)目引用了別人的一個項(xiàng)目,你的項(xiàng)目中有一個__autoload,別人的項(xiàng)目也有一個__autoload,這樣兩個__autoload就沖突了。解決的辦法就是修改__autoload成為一個,這無疑是非常繁瑣的。
因此我們急需使用一個autoload調(diào)用堆棧,這樣spl的autoload系列函數(shù)就出現(xiàn)了。你可以使用spl_autoload_register注冊多個自定義的autoload函數(shù)
如果你的php版本大于5.1的話,你就可以使用spl_autoload
先了解spl的幾個函數(shù):

spl_autoload 是_autoload()的默認(rèn)實(shí)現(xiàn),它會去include_path中尋找$class_name(.php/.inc)
Spl_autoload實(shí)現(xiàn)自動加載:
復(fù)制代碼 代碼如下:
/*http.php*/
<?php
class http
{
public function callname(){
echo "this is http";
}
}
/*test.php*/
<?php
set_include_path("/home/yejianfeng/handcode/"); //這里需要將路徑放入include
spl_autoload("http"); //尋找/home/yejianfeng/handcode/http.php
$a = new http();
$a->callname();
Spl_autoload_register
將函數(shù)注冊到SPL __autoload函數(shù)棧中,直接看一個例子:
復(fù)制代碼 代碼如下:
/*http.php*/
<?php
class http
{
public function callname(){
echo "this is http";
}
}
/*test.php*/
<?php
spl_autoload_register(function($class){
if($class == 'http'){
require_once("/home/yejianfeng/handcode/http.php");
}
});
$a = new http();
$a->callname();
spl_autoload_call
調(diào)用spl_autoload_register中注冊的調(diào)用函數(shù), 看下面的例子
復(fù)制代碼 代碼如下:
/*http.php*/
<?php
class http
{
public function callname(){
echo "this is http";
}
}
/*http2.php*/
<?php
class http
{
public function callname(){
echo "this is http2";
}
}
/*test.php*/
<?php
spl_autoload_register(function($class){
if($class == 'http'){
require_once("/home/yejianfeng/handcode/http.php");
}
if($class == 'http2'){
require_once("/home/yejianfeng/handcode/http2.php");
}
});
spl_auto_call('http2');
$a = new http();
$a->callname(); //這個時候會輸出"this is http2"
spl_auto_register這個函數(shù)使得我們不使用__autoload,使用自定義的函數(shù)來進(jìn)行自動加載成為可能。這個方法現(xiàn)在是經(jīng)常使用到的。
Zend的AutoLoader模塊就使用了這個方法。摘錄其中對應(yīng)的代碼
復(fù)制代碼 代碼如下:
spl_autoload_register(array(__CLASS__, 'autoload'));
public static function autoload($class)
{
…..
}
建議參考文章:
關(guān)于zend的autoload機(jī)制,前面有篇文章http://www.jb51.NET/article/31399.htm 有詳細(xì)分析。
關(guān)于autoload的自動加載機(jī)制,這篇文章http://www.jb51.NET/article/31279.htm說得非常詳細(xì),從底層開始分析。
php技術(shù):說說PHP的autoLoad自動加載機(jī)制,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。