spl_autoload_register與autoload的區別詳解
spl_autoload_register
(PHP 5 >= 5.1.2)
spl_autoload_register — 註冊__autoload()函數
說明
bool spl_autoload_register ([ callback $autoload_function ] )
將函數註冊到SPL __autoload函數棧中。如果該棧中的函數尚未激活,則激活它們。
如果在你的程序中已經實現了__autoload函數,它必須顯式註冊到__autoload棧中。因為
spl_autoload_register()函數會將Zend Engine中的__autoload函數取代為spl_autoload()或
spl_autoload_call()。
參數
欲註冊的自動裝載函數。如果沒有提供任何參數,則自動註冊autoload的默認實現函數
spl_autoload()。
返回值
如果成功則返回 TRUE,失敗則返回 FALSE。
註:SPL是Standard PHP Library(標準PHP庫)的縮寫。它是PHP5引入的一個擴展庫,其主要功能包括autoload機制的實現及包括各種Iterator接口或類。SPL autoload機制的實現是通過將函數指針autoload_func指向自己實現的具有自動裝載功能的函數來實現的。SPL有兩個不同的函數spl_autoload, spl_autoload_call,通過將autoload_func指向這兩個不同的函數地址來實現不同的自動加載機制。
範例
<?php class A { public function __construct() { echo ‘Got it.‘; } }
然後我們有一個index.php需要用到這個類A,常規的寫法就是
1 <?php 2 require(‘A.php‘); 3 $a = new A();
但是有一個問題就是,假如我們的index.php需要包含的不只是類A,而是需要很多類,這樣子就必須寫很多行require語句,有時候也會讓人覺得不爽。
不過在php5之後的版本,我們就不再需要這樣做了。在php5中,試圖使用尚未定義的類時會自動調用autoload函數,所以我們可以通過編寫__autoload函數來讓php自動加載類,而不必寫一個長長的包含文件列表。
例如在上面那個例子中,index.php可以這樣寫:
<?php function __autoload($class) { $file = $class . ‘.php‘; if (is_file($file)) { require_once($file); } } $a = new A();
當然上面只是最簡單的示範,__autoload只是去include_path尋找類文件並加載,我們可以根據自己的需要定義__autoload加載類的規則。
此外,假如我們不想自動加載的時候調用__autoload,而是調用我們自己的函數(或者類方法),我們可以使用spl_autoload_register來註冊我們自己的autoload函數。它的函數原型如下:
bool spl_autoload_register ( [callback $autoload_function] )
我們繼續改寫上面那個例子:
1 <?php 2 function loader($class) 3 { 4 $file = $class . ‘.php‘; 5 if (is_file($file)) { 6 require_once($file); 7 } 8 } 9 spl_autoload_register(‘loader‘); 10 $a = new A();
這樣子也是可以正常運行的,這時候php在尋找類的時候就沒有調用__autoload而是調用我們自己定義的函數loader了。同樣的道理,下面這種寫法也是可以的:
1 <?php 2 class Loader 3 { 4 public static function loadClass($class) 5 { 6 $file = $class . ‘.php‘; 7 if (is_file($file)) { 8 require_once($file); 9 } 10 } 11 } 12 spl_autoload_register(array(‘Loader‘, ‘loadClass‘)); 13 $a = new A();
轉載自 http://www.jb51.net/article/37746.htm
spl_autoload_register與autoload的區別詳解