|
復(fù)制代碼 代碼如下:
class ClassA{
public function __construct(){
echo “ClassA load success!”;
}
}
//定義一個(gè)類ClassA,文件名為ClassA.php
class ClassA{
public function __construct(){
echo “ClassA load success!”;
}
}
class ClassB extends ClassA {
public function __construct(){
//parent::__construct();
echo “ClassB load success!”;
}
}
//定義一個(gè)類ClassB,文件名為ClassB.php,ClassB繼承ClassA
class ClassB extends ClassA {
public function __construct(){
//parent::__construct();
echo “ClassB load success!”;
}
}
定義兩個(gè)測試用的類之后,我們來編寫一個(gè)含有__autoload()方法的php運(yùn)行程序文件如下:
function __autoload($classname){
$classpath=”./”.$classname.'.php';
if(file_exists($classpath)){
require_once($classpath);
}
else{
echo ‘class file'.$classpath.'not found!';
}
}
$newobj = new ClassA();
$newobj = new ClassB();
這個(gè)文件的運(yùn)行是一點(diǎn)問題都沒有的,可見autoload是多么的好用啊,呵呵……
但是不得不提醒你一下幾個(gè)方面是必須要注意的。
1、如果類存在繼承關(guān)系(例如:ClassB extends ClassA),并且ClassA不在ClassB所在目錄
利用__autoload魔術(shù)函數(shù)實(shí)例化ClassB的時(shí)候就會(huì)受到一個(gè)致命錯(cuò)誤:
Fatal error: Class ‘Classd' not found in ……ClassB.php on line 2,
解決方法:把所有存在extends關(guān)系的類放在同一個(gè)文件目錄下,或者在實(shí)例化一個(gè)繼承類的時(shí)候在文件中手工包含被繼承的類;
2、另外一個(gè)需要注意的是,類名和類的文件名必須一致,才能更方便的使用魔術(shù)函數(shù)__autoload;
其他需要注意的事情:
3、在CLI模式下運(yùn)行php腳本的話這個(gè)方法無效;
4、如果你的類名稱和用戶的輸入有關(guān)――或者依賴于用戶的輸入,一定要注意檢查輸入的文件名,例如:.././這樣的文件名是非常危險(xiǎn)的。
php技術(shù):PHP __autoload函數(shù)(自動(dòng)載入類文件)的使用方法,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。