前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Laravel框架中composer自动加载的实现分析

Laravel框架中composer自动加载的实现分析

作者头像
用户8832582
修改2021-07-14 11:05:11
8570
修改2021-07-14 11:05:11
举报
文章被收录于专栏:编程随想编程随想

基础

自动加载允许你通过即用即加载的方式来加载需要的类文件,而不用每次都写繁琐的require 和include语句。因此,每一次请求的执行过程都只加载必须的类,也不不要关心类的加载问题,只要需要的时候直接使用即可。

laravel 框架是通过composer 实现的自动加载。

是通过  下面的代码实现的。

require_once

. '/composer' . '/autoload_real.php';

return ComposerAutoloaderInit7b20e4d61e2f88170fbbc44c70d38a1f::getLoader();

首先我们对spl_autoload_register和spl_autoload_unregister 这两个函数进行解释一下。

spl_autoload_register 自动注册 一个或多个 自动加载函数,这些函数一般在 实例化类的时候,自动运行。

spl_autoload_unregister 恰恰相反。

贴上我实验的代码:

这是autoload.php

<?php

/**

namespace app;

class Autoload {

public function __construct()

{

$this->autoload();

}

public function autoload(){

// spl_autoload_register(array('Autoload','ss'),true); 会触发致命错误,必须带上命名空间

spl_autoload_register(array('appAutoload','ss'),true);

}

public function ss(){

echo 666;

exit;

}

}

这是index.php

<?php

/**

require 'autoload.php';

$autoload=new appAutoload();

$b=new B();// 此时自动运行自动加载函数

echo 77;

exit;

找到getLoader 这个函数,并对其进行分析:

public static function getLoader()

{

if (null !== self::$loader) {

return self::$loader;

}

//注册自动加载函数,在加载或实例化类,运行loadClassLoader函数

spl_autoload_register(array('ComposerAutoloaderInit7b20e4d61e2f88170fbbc44c70d38a1f', 'loadClassLoader'), true, true);

self::$loader = $loader = new ComposerAutoloadClassLoader();

spl_autoload_unregister(array('ComposerAutoloaderInit7b20e4d61e2f88170fbbc44c70d38a1f', 'loadClassLoader'));

/

*

$map = require

. '/autoload_namespaces.php';

foreach ($map as $namespace => $path) {

$loader-&gt;set($namespace, $path);

}

$map = require

. '/autoload_psr4.php';

foreach ($map as $namespace => $path) {

$loader-&gt;setPsr4($namespace, $path);

}

$classMap = require

. '/autoload_classmap.php';

if ($classMap) {

$loader-&gt;addClassMap($classMap);

}

/

*

$loader-&gt;register(true); $includeFiles = require

. '/autoload_files.php'; foreach ($includeFiles as $fileIdentifier => $file) { composerRequire7b20e4d61e2f88170fbbc44c70d38a1f($fileIdentifier, $file); } return $loader; }}

/

包围的部分,主要对ClassLoader 中的

$prefixesPsr0&nbsp;&nbsp; 、$prefixDirsPsr4  、$classMap 等属性进行赋值。即加载一些配置好的文件,在后面进行加载或寻找文件时候,就是从加载的配置文件中寻找。寻找要加载的类主要通过register 函数来实现。然后分析register函数。

public function register($prepend = false)

{

spl_autoload_register(array($this, 'loadClass'), true, $prepend);

}

发现实际将该类中loadClass 函数注册为自动加载函数。于是开始分析loadClass函数,最终是通过findFile进行类的寻找。

public function findFile($class)

{

/// 特别注意 参数$class 是根据命名空间生成的class名称,具体请参考命名空间特性。

// work around for PHP 5.3.0 - 5.3.2

if ('\' == $class[0]) {

$class = substr($class, 1);

}

// class map lookup 首先从加载的classMap 中寻找

if (isset($this-&gt;classMap[$cl/

/ass])) {

return $this-&gt;classMap[$class];

}

if ($this->classMapAuthoritative) {

return false;

}

// 从刚才加载的配置文件中寻找文件。先按照 psr4 规则寻找,再按照psr0 寻找

// 两种规则的不同主要是对下划线的处理方式。

$file = $this->findFileWithExtension($class, '.php');

// Search for Hack files if we are running on HHVM

if ($file === null && defined('HHVM_VERSION')) {

$file = $this->findFileWithExtension($class, '.hh');

}

if ($file === null) {

// Remember that this class does not exist.

return $this-&gt;classMap[$class] = false;

}

return $file;

}

至此register函数分析完。我们接着分析getLoader函数剩余代码。

$includeFiles = require

. '/autoload_files.php';

foreach ($includeFiles as $fileIdentifier => $file) {

composerRequire7b20e4d61e2f88170fbbc44c70d38a1f($fileIdentifier, $file);

}

这段代码其实就是加载autoload_file.php 文件。

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

/

/

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
SSL 证书
腾讯云 SSL 证书(SSL Certificates)为您提供 SSL 证书的申请、管理、部署等服务,为您提供一站式 HTTPS 解决方案。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档