php autoload自动加载类的用法总结

发布时间:2020-10-09编辑:脚本学堂
本文介绍下,在php编程中,使用autoload自动加载类的方法,通过实例来学习下autoload自动加载类的用法,有兴趣的朋友参考学习下。

本节内容:
php autoload自动加载类

PHP中提供了Autoload来实现文件的自动包含。

本文总结下,php中使用autoload的一些问题。

一,php的Autoload

在PHP中使用类时,必须在使用前加载进来,不管是通过 require 的方式还是 include 的方式,但是会有两个问题影响我们做出加载的决定。
首先,不确定类的存储位置,不知道何时需要用到这个文件。特别是项目文件特别多时,不可能每个文件都在开始的部分写很长一串的 require ….

在PHP5之后,可以通过 __autoload来解决这个问题。
而且在PHP5.1之后,还提供了 spl_autoload_register() 来提供更完善的加载机制。

二,Autoload 的加载机制

当通过 new 来实例化一个类时,PHP会通过定义的__autoload 函数加载相应的文件,如果这个类文件使用了 extends 或者 implements 需要用到其他的类文件,php会重新运行 autoload 去进行类文件的查找和加载,如果发生了两次对同一类文件的请求,就会报错。

一般情况下,有很多种方法来解决加载时到相应位置查找文件的方法。用的最多的就是指定特定的命名标准。

Zend的方法

zend推荐了一种最流行的办法,在文件名中包含路径。

例子:
 

复制代码 代码示例:
<?php
// Main.class
function __autoload($class_name) {
    $path = str_replace('_', DIRECTORY_SEPARATOR, $class_name);
    require_once $path.'.php';
}
$temp = new Main_Super_Class(); 所有的下划线都会被替换成路径中的分隔符,上例中就会去 Main/Super/Class.php文件

缺点:
在编码过程中,我们必须明确的知道代码文件应当所处的位置,而且由于将文件路径硬编码在了类名中,如果需要修改文件夹的结构时,必须手工修改所有的类名。
'Include All'方法
如果是在一个开发环境中,并且对于速度不是很在意的话,使用这个方法是非常方便的。
通过将所有类文件放在一个或几个特定文件夹中,然后通过遍历的方式查找加载。

例如:
 

复制代码 代码示例:
<?php
  $arr = array (
    'Project/Classes',
    'Project/Classes/Children',
    'Project/Interfaces'
  );
  foreach($arr as $dir) {
    $dir_list = opendir($dir);
    while ($file = readdir($dir_list)) {
      $path = $dir.DIRECTORY_SEPARATOR.$file;
      if(in_array($file, array('.', '..')) || is_dir($path))
        continue;
      if (strpos($file, ".class.php"))
        require_once $path;
    }
  }
?>

关联文件和位置

在类文件和他的位置之间建立关联的配置文件,例如:
 

复制代码 代码示例:
<?php
// configuration.php
array_of_associations = array(
  'MainSuperClass' = 'C:/Main/Super/Class.php',
  'MainPoorClass' = 'C:/blablabla/gy.php'
);

调用的文件:
 

复制代码 代码示例:
<?php
  require 'autoload_generated.php';
  function __autoload($className) {
    global $autoload_list;
    require_once $autoload_list[$className];
  }
  $x = new A();
?>

当然,如果文件特别多时,维护起来会是一件麻烦事,但是与在类名中硬编码位置,哪个更好呢?

当然不希望手工来维护这个列表,那么可以使用自动生成这个文件来实现,这个对应关系的文件可以是phpxmljson等。