它调用了 getLoader() 函数,并将 loadClassLoader 函数注册到加载函数注册队列。然后就可以通过命名空间的方式 self::$loader = $loader = new \Composer\Autoload\ClassLoader(); 实例化 ClassLoader 类。
紧接着,他载入了 /autoload_static.php 文件,大致内容如下
// 里面还定义了包类和psr的一些标准 public static $classMap = array ( 'App\\Common\\Collection' => __DIR__ . '/../..' . '/app/Common/Collection.php', 'App\\Common\\MgDB' => __DIR__ . '/../..' . '/app/Common/MgDB.php', 'App\\Common\\Redis' => __DIR__ . '/../..' . '/app/Common/Redis.php', )
看到这里笔者兴奋了,因为上面的 Collection, Redis 正是笔者定义的类!
然后就是我们在laravel经常听到的一个名词 “register”。查看 ClassLoader 类的 register 方法如下:
public function register($prepend = false) { spl_autoload_register(array($this, 'loadClass'), true, $prepend); } public function loadClass($class) { if ($file = $this->findFile($class)) { includeFile($file); return true; } } public function findFile($class) { // ... // class map lookup if (isset($this->classMap[$class])) { return $this->classMap[$class]; } // ... }
上面的register方法同样使用了自动加载机制。并将通过findFile函数和$classMap数组直接找到对应的类的具体位置。这也就是我们不用自己去加载类文件的原因 – 当我们实例化一个代码中找不到的类时,它便会在这里加载对应的类。
看到这里我们也发现了它的使用和我们之前讲的并不完全一致,我们是注册函数是为了通过文件夹来寻找类,而laravel注册函数是为了注册一个映射数组然后直接调用(整了个映射文件三千多行。。。)具体为什么要这么做得等下次通读加载源码部分后再写一篇博文(本来只想找一个框架的例子,蜜汁尴尬)
笔者实例两年前负责学校某个协会线上部分时,主要是做微信开发,因为时不时就要加一个新功能,所以如果用一般的方式写起来是比较痛苦的,但是用框架又有点大材小用。因为就使用了下面这种简单的方式:
require "./basic/init.php"; define('WEB_PATH', ''); //声明自动加载函数并注册,指示加载路径与加载方法 function wechatAutoload($class_name) { $file_road = './function/'.$class_name.'.class.php'; if(file_exists($file_road)) { require_once($file_road); } } spl_autoload_register('wechatAutoload'); //----------------------------------------------
初始化好配置之后,我们注册了一个加载函数,以后每一个新功能都只要在 function 文件夹下新增一个文件即可,其他部分的改动很少或者根本不用(根据业务场景)。
参考:PHP: spl_autoload_register - Manual
更多关于PHP相关内容感兴趣的读者可查看本站专题:《php面向对象程序设计入门教程》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》