這裡通過一個實驗談談這個函數的部分特徵。
函數原型
bool spl_autoload_register ([ callback $autoload_function [, bool $throw = true [, bool $prepend = false ]]] )
版本相容
PHP 5 >= 5.1.2
實驗過程
第一步,使用spl_autoload_register()函數註冊load()方法
複製代碼 代碼如下:
<?php
function load(){
require_once 'lib.php';
}
spl_autoload_register('load');
?>
其中lib.php檔案代碼如下
複製代碼 代碼如下:
<?php
class className{
function method(){
echo 'a method in class';
}
}
function onlyMethod(){
echo 'method only';
}
?>
說明:lib.php檔案為一個className類和一個onlyMethod函數
第二步,調用自動載入類
複製代碼 代碼如下:
$class = new className();
$class->method();
onlyMethod();
輸出:
a method in class
method only
說明:執行個體化className類,並調用類method()函數,同時調用onlyMethod()方法,輸出正常,沒有出現錯誤
第三步,直接調用函數
onlyMethod();
說明:沒有執行個體化類,直接調用lib.php檔案中的onlyMethod()函數
輸出:
Fatal error: Call to undefined function onlyMethod() in '...(省略路徑)'
第四步,執行個體化className類,再直接調用
$class = new className();
onlyMethod();
輸出:method only
從上面的四步實驗發現,如果載入的檔案包含函數,使用則一定需要執行個體化裡面的類,否則就產生異常情況 Call to undefined function錯誤,具體在使用中要注意一下。
參與資料:spl_autoload_register