WithCoderWithCoderWithCoder

PHP函数学习之spl_autoload_register()的使用

在PHP中编写面向对象(OOP) 程序时,我们经常会为每个类新建一个 PHP 文件。 不过这会存在一个问题(类似Java,.Net):每个脚本的开头,都需要包含(include)一个长长的列表(每个类都有个文件)。

不过,在 PHP 5 中,已经不再需要这样了。我们可以使用 spl_autoload_register() 函数,注册任意数量的自动加载器,当使用尚未被定义的类(class)和接口(interface)时自动去加载。通过注册自动加载器,脚本引擎在 PHP 出错失败前有了最后一个机会加载所需的类。

尽管 __autoload() 函数也能自动加载类和接口,但官方更建议使用 spl_autoload_register() 函数。 spl_autoload_register() 提供了一种更加灵活的方式来实现类的自动加载(同一个应用中,可以支持任意数量的加载器,比如第三方库中的)。因此,不再建议使用 __autoload() 函数,在以后的版本中它可能被弃用。

函数说明

    spl_autoload_register ([ callable $autoload_function [, bool $throw = true [, bool $prepend = false ]]] ) : bool

        spl_autoload_register() 函数注册给定的函数作为 __autoload 的实现。

        参数

          autoload_function

            要注册的自动装载函数。如果没有提供任何参数,则自动注册 autoload 的默认实现函数spl_autoload()。

          throw

            此参数设置了 autoload_function 无法成功注册时, spl_autoload_register()是否抛出异常。

          prepend

            如果是 true,spl_autoload_register() 会添加函数到队列之首,而不是队列尾部。

返回值               

            在注册成功时返回 TRUE, 或者在失败时返回 FALSE。

       spl_autoload_register() 函数将函数注册到SPL __autoload函数队列中。如果该队列中的函数尚未激活,则激活它们。

       如果在程序中已经实现了__autoload()函数,它必须显式注册到__autoload()队列中。因为 spl_autoload_register()函数会将Zend Engine中的__autoload()函数取代为spl_autoload()或spl_autoload_call()。如果需要多条 autoload 函数,spl_autoload_register() 满足了此类需求。 它实际上创建了 autoload 函数的队列,按定义时的顺序逐个执行。相比之下, __autoload() 只可以定义一次。

举例  

定义类MyClass.php  

<?php

class MyClass
{
    function __construct()
    {
        echo '初始化类:MyClass';
    }

    function myMethod()
    {
        echo 'hello world';
    }
}

    定义文件index.php

<?php
// 方法
spl_autoload_register(function ($name) {
   require $name . '.php';
   echo '载类' . $name;
});

$myClass = new MyClass();

    以上代码输出:

 装载类:MyClass初始化类:MyClass


欢迎分享交流,转载请注明出处:WithCoder » PHP函数学习之spl_autoload_register()的使用