类主动加载

Composer是一种PHP包管理工具,可用于管理应用程序所依赖的第三方库。 Composer能够通过主动加载性能来加载这些依赖项。

Composer应用主动加载机制,该机制应用非凡的PHP函数在须要时加载类。 这个函数称为主动加载器函数,并且是在PHP脚本开始执行之前调用的。

当PHP解析器遇到未定义的类时,它会调用主动加载器函数。 主动加载器函数承受类名作为参数,并应用这个类名来确定应该加载哪个文件。 例如,如果类名为Foo\\Bar,则主动加载器函数可能会尝试加载/path/to/project/src/Foo/Bar.php文件。

Composer自身有一些内置的主动加载性能,这些性能能够用于加载应用程序所依赖的库。 例如,Composer能够应用PSR-4主动加载标准加载类。 这种标准应用命名空间和文件构造来确定应该加载哪些文件。 要应用PSR-4主动加载,您须要在应用程序的composer.json文件中指定命名空间前缀和文件路

在应用时,通常只须要蕴含以下类主动加载入口文件即可实现

require 'vendor/autoload.php';

PSR-4类主动加载标准

PSR-4(PHP Standard Recommendation 4)是PHP主动加载标准的一种。 它提供了一种规范办法,用于应用命名空间和文件构造来加载PHP类。

在PSR-4标准中,每个命名空间都有一个对应的文件夹。 例如,如果您有一个命名空间为Foo\\Bar,则能够将相应的类文件放在/path/to/project/src/Foo/Bar文件夹中。
在PSR-4标准中,类名通常与文件名雷同。 例如,如果您有一个命名空间为Foo\\Bar,并且有一个类名为Baz,则能够将此类定义放在/path/to/project/src/Foo/Bar/Baz.php文件中。

应用PSR-4标准时,您须要在应用程序的composer.json文件中指定命名空间前缀和文件门路。 Composer会应用这些信息来生成主动加载代码,并将其写入autoload_psr4.php文件中。 当您的利用程序运行时,Composer会加载此文件,并应用主动加载器函数来加载类。

几个文件剖析

vendor/autoload.php

入口文件,间接蕴含 autoload_real.php 文件,并且调用以下办法注册所有可用 namespace、类、文件等。

ComposerAutoloaderInitxxxxxx::getLoader()

vendor/composer/autoload_classmap.php

返回数组,蕴含所有单个类名→类文件的主动加载文件

vendor/composer/autoload_files.php

返回数组,蕴含了所有须要主动加载的PHP文件,通常是一些全局函数等。

vendor/composer/autoload_namespaces.php

返回数组,蕴含了主动加载namespace的映射关系。

vendor/composer/autoload_psr4.php

返回数组,蕴含恪守PSR-4主动加载标准的命名空间→文件门路的列表。