PHP 面向对象高级:类的自动加载 1 个改进

类的自动加载

前言

在使用面向对象模式开发程序时,通常大家习惯为每个类都创建一个单独的 PHP 源文件。这样会很容易实现对类进行复用,同时将来维护时也很便利,这也是面向对象程序设计的基本思想之一。

PHP5 之前,如果希望从外部引入一个 class ,通常会使用 includerequire ,去把定义这个 class 的文件包含进来即可。这个在小规模开发的时候,没什么大问题。但在大型的开发项目中,这么做会产生大量的include 或者 require方法调用,这样不仅效率低下,而且使得代码难以维护,况且 require_once 的代价很大。

开始

PHP 提供了 __autoload()spl_autoload_register() 函数来实现类的自动加载功能,这可以节省编程的时间。

1、__autoload() 函数

__autoload() 是系统函数,名称是固定的,而且该函数没有方法体,需要我们自定义方法体。另外,该函数是自动调用的,当我们 new 一个类时,如果当前源文件中找不到这个类,PHP 则会自动调用 __autoload() 函数,并将类名传递给 __autoload() 函数。

还有一点需要注意的是, __autoload() 函数在当前源文件中只能定义一次。语法格式如下:

function __audoload($class)
{
    //方法体
}

其中 $class 为要加载的类名。

提示: 想要使用 __autoload() 函数自动加载类文件,类文件的名称需要与类名相同,另外一个类文件中只能定义一个类。

示例 使用 __autoload() 函数自动加载类文件
function __autoload($class)
{
    $file = './'.$class.'php';
    include_once($file);    
}

$obj = new Demo();

运行上面的代码,会自动加载同目录下的 Demo.php 文件,Demo.php 中的代码如下所示:

class Demo
{

}

提示: __autoload() 函数自 PHP7.2 起已被弃用,可以使用 spl_autoload_register() 函数代替。

2、spl_autoload_register() 函数

spl_autoload_register() 函数可以指定一个函数来替代 __autoload() 函数的功能。语法格式如下:

spl_autoload_register ($autoload_function = null, $throw = true, $prepend = false)

参数说明:

  • $autoload_function:要替代 __autoload() 函数的函数名称,也可以是一个匿名函数。如果没有提供任何参数,则自动注册 autoload 的默认实现函数 spl_autoload()
  • $throw:用来设置 $autoload_function 无法成功注册时,spl_autoload_register() 函数是否抛出异常
  • $prepend:如果是 true ,则 spl_autoload_register() 函数会添加 $autoload_function 函数到队列之首,否则添加到队列尾部

注意:与 __autoload() 函数不同,spl_autoload_register() 可以多次定义。

示例 使用 spl_autoload_register() 函数指定另一个函数来替代 __autoload() 函数
spl_autoload_register('loadClass');

function loadClass($class)
{
    $file = './'.$class.'php';
    include_once($file); 
}

$obj = new Demo();

运行上面的代码同样需要上面示例中用到的 Demo.php 文件。

本文为 Wiki 文章,邀您参与纠错、纰漏和优化
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!