本文實例講述了PHP 自動加載類原理與用法。分享給大家供大家參考,具體如下:
類的自動加載 (Autoloading Classes)
在編寫面向對象(OOP) 程序時,很多開發者為每個類新建一個 PHP 文件。 這會帶來一個煩惱:每個腳本的開頭,都需要包含(include)一個長長的列表(每個類都有個文件)。
在 PHP 5 中,已經不再需要這樣了。 spl_autoload_register() 函數可以注冊任意數量的自動加載器,當使用尚未被定義的類(class)和接口(interface)時自動去加載。通過注冊自動加載器,腳本引擎在 PHP 出錯失敗前有了最后一個機會加載所需的類。
Tip
盡管 __autoload() 函數也能自動加載類和接口,但更建議使用 spl_autoload_register() 函數。spl_autoload_register() 提供了一種更加靈活的方式來實現類的自動加載(同一個應用中,可以支持任意數量的加載器,比如第三方庫中的)。因此,不再建議使用 __autoload() 函數,在以后的版本中它可能被棄用。
Note:
在 PHP 5.3 之前,__autoload 函數拋出的異常不能被 catch 語句塊捕獲并會導致一個致命錯誤(Fatal Error)。 自 PHP 5.3 起,能夠 thrown 自定義的異常(Exception),隨后自定義異常類即可使用。 __autoload 函數可以遞歸的自動加載自定義異常類。
Note:
自動加載不可用于 PHP 的 CLI 交互模式。
Note:
如果類名比如被用于 call_user_func(),則它可能包含一些危險的字符,比如 ../。 建議您在這樣的函數中不要使用用戶的輸入,起碼需要在 __autoload() 時驗證下輸入。
自動加載示例
ClassInterface.php
1
2
3
4
5
|
<?php interface ClassInterface { public function print (); public function get_current_time(); } |
MyClass1.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<?php class MyClass1 implements ClassInterface { public $flag = 'MyClass1' ; public function print () { echo $this ->flag; } public function get_current_time() { echo $this ->flag . " : " . date ( "Y-m-d H:i:s" ,time()); } } |
MyClass2.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<?php class MyClass2 implements ClassInterface { public $flag = 'MyClass2' ; public function print () { echo "MyClass2" ; } public function get_current_time() { echo $this ->flag . " : " . date ( "Y-m-d H:i:s" ,time()); } } |
autoload.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<?php date_default_timezone_set( 'Asia/Shanghai' ); spl_autoload_register( function ( $class_name ) { require_once $class_name . '.php' ; }); $obj = new MyClass1(); $obj2 = new MyClass2(); $obj -> print (); echo "<br>" ; $obj ->get_current_time(); echo "<br>" ; $obj2 -> print (); echo "<br>" ; $obj2 ->get_current_time(); |
輸出結果:
希望本文所述對大家PHP程序設計有所幫助。
原文鏈接:https://www.cnblogs.com/ryanzheng/p/11405142.html