PHP基礎之類和對象4——自動加載對象
很多開發者寫面向對象的應用程序時對每個類的定義建立一個 PHP 源文件。一個很大的煩惱是不得不在每個腳本開頭寫一個長長的包含文件列表(每個類一個文件)。
在 PHP 5 中,不再需要這樣了。可以定義一個?__autoload()?函數,它會在試圖使用尚未被定義的類時自動調用。通過調用此函數,腳本引擎在 PHP 出錯失敗前有了最后一個機會加載所需的類。
Tip
spl_autoload_register()?提供了一種更加靈活的方式來實現類的自動加載。因此,不再建議使用?__autoload()?函數,在以后的版本中它可能被棄用。
Note:
在 5.3.0 版之前,__autoload 函數拋出的異常不能被?catch?語句塊捕獲并會導致一個致命錯誤。從 5.3.0+ 之后,__autoload 函數拋出的異常可以被?catch?語句塊捕獲,但需要遵循一個條件。如果拋出的是一個自定義異常,那么必須存在相應的自定義異常類。__autoload 函數可以遞歸的自動加載自定義異常類。
Note:
自動加載不可用于 PHP 的 CLI?交互模式。
Example #1 自動加載示例
本例嘗試分別從 MyClass1.php 和 MyClass2.php 文件中加載?MyClass1?和?MyClass2?:
function __autoload($class_name){
require_once $class_name.’.php’;
}
$obj = new MyClass1();
$obj2 = new MyClass2();
注意:MyClass1.php和MyClass2.php需要和當前腳本在同一目錄才能加載到
Example #2 另一個例子
本例嘗試加載接口?ITest:
function?__autoload($name) {
???var_dump($name);
}
class?Foo?implements?ITest?{
}
/*
string(5) 'ITest'
Fatal error: Interface ’ITest’ not found in ...
*/
Example #3 自動加載在 PHP 5.3.0+ 中的異常處理
本例拋出一個異常并在 try/catch 語句塊中演示。
function?__autoload($name) {
???echo?'Want to load?$name.n';
???throw new?Exception('Unable to load?$name.');
}
try {
???$obj?= new?NonLoadableClass();
} catch (Exception $e) {
???echo?$e->getMessage(),?'n';
}
以上例程會輸出:
Want to load NonLoadableClass.Unable to load NonLoadableClass.
Example #4 自動加載在 PHP 5.3.0+ 中的異常處理 - 沒有自定義異常機制
本例將一個異常拋給不存在的自定義異常處理函數。
以上例程會輸出:
Want to load NonLoadableClass.Want to load MissingException.Fatal error: Class ’MissingException’ not found in testMissingException.php on line 4
了解更多參見unserialize()
unserialize_callback_func
spl_autoload()
spl_autoload_register()
相關文章: