详解composer自动加载机制

发布时间:2023-10-06 点击:131
下面由composer教程栏目给大家由浅入深的介绍composer自动加载机制,希望对需要的朋友有所帮助!
前言
由于对于composer自动加载机制的记忆只剩下了"spl_auto?"和"根据命名空间来推导出文件路径"这两个了。。。还是残缺的。。
本想网上收藏一篇详解,奈何,没发现符合我觉得的"由浅入深"文章。
所以有了这篇笔记。
以下知识点即将赶来:
1.了解一下spl_autoload_register
2.composer update发生的故事
3.追踪一下composer的自动加载
正文1.了解一下spl_autoload_register
首先查一下php官方手册:
(偷懒可以只看红色部分即可)
是不是看着一知半解?
来用白话文来翻译一下:
我们new一个类的话,必须先require或者include类的文件,如果没有加载进来则会报错。这产生一个问题:那这样的话文件的头部到处都是requies和include,明显不符合程序员必须"偷懒"尿性。
为了不需要require或者include类文件也能正常的new一个类,出现了自动加载机制。spl_autoload_register这个函数就专门干这个事的。
从截图得知,此函数有三个参数:
参数详解autoload_function这里填的是一个*"函数"的名称*,字符串或者数组,这个函数的功能就是把需要new的文件require或者include尽量,避免new的时候报错。简单的说就是要你封装一个*自动加载文件的函数*throw当自动加载的函数无法注册的时候,是否抛异常prepend是否添加函数到函数队列之首,如果是true则为首,否则尾部
来一波代码,印象深刻一些:
//文件 testclass.php ,即将new的类class testclass{ public function __construct() { echo '你已经成功new了我了'; }}//文件autoloaddemo.php文件spl_autoload_register('autoload_function', true, true);function autoload_function($class_name){ echo "所有的require或者include文件工作都交给我吧!\\\\r\\\\n"; $class_filename = "./{$class_name}.php"; echo "我来加载{$class_filename}文件\\\\r\\\\n"; require_once("./{$class_name}.php");}$obj_demo = new testclass();输出:
所有的require或者include文件工作都交给我吧!我来加载testclass.php文件你已经成功new了我了明白了这个加载的原理,看下文就顺利多了。
2.composer update发生的故事
将自动加载之前,必须要先说一下composer update,这里头承载了自动加载的前提。
composer项目都包含一个composer.json的配置文件。
这里头有一个关键的字段"autoload",包含psr-4和files两个字段。
psr-4:说明是基于psr-4规范的类库,都支持自动加载,只要在后面的对象中以“命名空间:路径”的方式写入自己的类库信息即可。
files:这就就更直接了,写入路径就自动加载。
按照以上配置每回composer update之后呢,都会更新一个很重要的文件:./vender/composer/autoload_psr4.php。
这个文件只做了一件事情:把命名空间和文件路径对应起来,这样后续自动加载就有映射根据了。
3.追踪一下composer的自动加载
composer的故事从唯一的一个require说起:
require '../vendor/autoload.php'这个脚本执行了一个函数:
composerautoloaderinitd9b31141b114fcbee3cf55d0e97b7f87::getloader()继续跟getloader函数做了什么?
public static function getloader() { if (null !== self::$loader) { return self::$loader; } spl_autoload_register(array('composerautoloaderinitd9b31141b114fcbee3cf55d0e97b7f87', 'loadclassloader'), true, true); self::$loader = $loader = new \\\\composer\\\\autoload\\\\classloader(); spl_autoload_unregister(array('composerautoloaderinitd9b31141b114fcbee3cf55d0e97b7f87', 'loadclassloader')); $usestaticloader = php_version_id >= 50600 && !defined('hhvm_version') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded()); if ($usestaticloader) { require_once __dir__ . '/autoload_static.php'; call_user_func(\\\\composer\\\\autoload\\\\composerstaticinitd9b31141b114fcbee3cf55d0e97b7f87::getinitializer($loader)); } else { $map = require __dir__ . '/autoload_namespaces.php'; foreach ($map as $namespace => $path) { $loader->set($namespace, $path); } $map = require __dir__ . '/autoload_psr4.php'; foreach ($map as $namespace => $path) { $loader->setpsr4($namespace, $path); } $classmap = require __dir__ . '/autoload_classmap.php'; if ($classmap) { $loader->addclassmap($classmap); } } $loader->register(true); if ($usestaticloader) { $includefiles = composer\\\\autoload\\\\composerstaticinitd9b31141b114fcbee3cf55d0e97b7f87::$files; } else { $includefiles = require __dir__ . '/autoload_files.php'; } foreach ($includefiles as $fileidentifier => $file) { composerrequired9b31141b114fcbee3cf55d0e97b7f87($fileidentifier, $file); } return $loader;}这个函数主要做了两件事情:
1.将各种存有命名空间和文件映射关系的文件autoload_xxx.php加载了进来,并作了一些处理(比如:setpsr4将相关映射加载了进去,这个留意下,下文会有呼应。)。
2.注册了函数register
继续跟踪register做了什么:
public function register($prepen

8核云服务器购买
服务器的租用云服务器
阿里云香港服务器需要备案不
网站后台数据没有-虚拟主机/数据库问题
电脑屏幕提示“电源已连接,未充电”怎么处理
阿里云服务器可以挂游戏吗安全吗
阿里云网站服务器和数据库服务器区别在哪
果然是它!立白旗下超威以188888元秒下这个域名