PHP在魔術函數__autoload()方法出現以前,如果你要在一個程序文件中實例化100個對象,那么你必須用include或者require包含進來100個類文件,或者你把這100個類定義在同一個類文件中——相信這個文件一定會非常大.
但是__autoload()方法出來了,以后就不必為此大傷腦筋了,這個類會在你實例化對象之前自動加載制定的文件.
下邊我們通過一個例子來看一下,具體的使用方法,并在稍后說明使用PHP魔術函數__autoload應該注意些什么,代碼如下:
- //定義一個類ClassA,文件名為ClassA.php
- class ClassA{
- public function __construct(){
- echo "ClassA 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、如果你的類名稱和用戶的輸入有關——或者依賴于用戶的輸入,一定要注意檢查輸入的文件名,例如:.././這樣的文件名是非常危險的.
新聞熱點
疑難解答