php 自動載入函數 __autoload()
PHP在魔術函數__autoload()方法出現以前,如果你要在一個程式檔案中執行個體化100個對象,那麼你必須用include或者require包含進來100個類檔案,或者你把這100個類定義在同一個類檔案中——相信這個檔案一定會非常大。
但是__autoload()方法出來了,以後就不必為此大傷腦筋了,這個類會在你執行個體化對象之前自動載入制定的檔案。
下邊我們通過一個例子來看一下,具體的使用方法,並在稍後說明使用PHP魔術函數__autoload應該注意些什麼。
class ClassA{
public function __construct(){
echo "ClassA load success!";
}
}
//定義一個類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!";
}
}
//定義一個類ClassB,檔案名稱為ClassB.php,ClassB繼承ClassA
class ClassB extends ClassA {
public function __construct(){
//parent::__construct();
echo "ClassB load success!";
}
}
定義兩個測試用的類之後,我們來編寫一個含有__autoload()方法的PHP運行程式檔案如下:
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();
這個檔案的運行是一點問題都沒有的,可見autoload是多麼的好用啊,呵呵……
但是不得不提醒你一下幾個方面是必須要注意的。
1、如果類存在繼承關係(例如:ClassB extends ClassA),並且ClassA不在ClassB所在目錄
利用__autoload魔術函數執行個體化ClassB的時候就會受到一個致命錯誤:
Fatal error: Class ‘Classd’ not found in ……ClassB.php on line 2,
解決方案:把所有存在extends關係的類放在同一個檔案目錄下,或者在執行個體化一個繼承類的時候在檔案中手工包含被繼承的類;
2、另外一個需要注意的是,類名和類的檔案名稱必須一致,才能更方便的使用魔術函數__autoload;
其他需要注意的事情:
3、在CLI模式下運行PHP指令碼的話這個方法無效;
4、如果你的類名稱和使用者的輸入有關——或者依賴於使用者的輸入,一定要注意檢查輸入的檔案名稱,例如:.././這樣的檔案名稱是非常危險的。
或者你還對:PHP魔術函數__call()感興趣!