这个函数很纠结,本来看了感觉很简单,也想也不对劲,搞明白了,分享一下!!

 

 

PHP函数spl_autoload_register实现自动加载研究

 

 

spl_autoload_register()函数应该是主流框架使用最多的也是非常核心的函数之一,可实现自动注册函数和类,实现类似__autoload() 函数功能,简化了类

 

的调用与加载,提高了工作的效率,这里通过一个实验谈谈这个函数的部分特征。

 

函数原型

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错误,具体在使用中

 

要注意一下。

 

自己看法:

如果加载的文件包含函数,使用则一定需要实例化里面的类,否则就产生异常情况 Call to undefined function错误,具体在使用中要注意一下。

上面一堆,就这句话感觉有价值。

看了一堆资料,终于搞明白这个函数了。

 

以上是从网上摘来的例子,每次使用都要通过require,麻烦,这样注册上,就和使用PHP自己的函数一样,不需要在include,方便,省事!!!

当然使用的时候注意第3,4部。版本兼容

PHP 5 >= 5.1.2

 

1

1.1

spl_autoload_register("ddd");

1.2

spl_autoload_register(array('YiiBase','autoload'));

1.1为ddd函数名

1.2YiiBase为类名,autoload为方法名

先看下面的事例

 

<?php

class YiiBase

{

public static function autoload($className)

      {

          // use include so that the error PHP file may appear

          if(isset(self::$_coreClasses[$className]))

              include(YII_PATH.self::$_coreClasses[$className]);

          else if(isset(self::$_classes[$className]))

              include(self::$_classes[$className]);

          else

          {

              include($className.'.php');

              return class_exists($className,false) || interface_exists($className,false);

          }

          return true;

      }

private static $_coreClasses=array(

          'CApplication' => '/base/CApplication.php',

          'CApplicationComponent' => '/base/CApplicationComponent.php',

          'CBehavior' => '/base/CBehavior.php',

          'CComponent' => '/base/CComponent.php',

          'CErrorEvent' => '/base/CErrorEvent.php',

          'CErrorHandler' => '/base/CErrorHandler.php',

          'CException' => '/base/CException.php',

);

 

}

 

spl_autoload_register(array('YiiBase','autoload'));

 

这个函数完成注册功能,

当new一个函数的时候,譬如

 

$aa = new CApplication(),在本文件找不到,程序就会转向__autoload()栈,spl_autoload_register()可以重写,譬如:当 spl_autoload_register(array

 

('YiiBase','autoload'));的时候,就不会转向__autoload()栈,

 

说明:

bool spl_autoload_register ([ callback $autoload_function ] )

将函数注册到SPL __autoload函数栈中。如果该栈中的函数尚未激活,则激活它们。

 

如果在你的程序中已经实现了__autoload函数,它必须显式注册到__autoload栈中。因为

 

spl_autoload_register()函数会将Zend Engine中的__autoload函数取代为spl_autoload()或

 

spl_autoload_call()。

 

好了说了这么多

在上面的那个例子

 

$aa = new CApplication(),找不到,就会通过spl_autoload栈寻找,也相当于执行函数YiiBase->autoload($className),其中$className在这里的值就是new 

 

CApplication(),中的CApplication,如果条件合格,加载这个文件。

OK

END!!!