1.命名空间
PHP 命名空间可以解决以下两类问题:
1) 用户编写的代码与PHP内部的类/函数/常量或第三方类/函数/常量之间的名字冲突。
2) 为很长的标识符名称(通常是为了缓解第一类问题而定义的)创建一个别名(或简短)的名称,提高源代码的可读性。
2.类自动加载
spl_autoload_register ([ callable
$autoload_function
[, bool$throw
= true [, bool$prepend
= false ]]] ) : bool
autoload_function:
欲注册的自动装载函数。如果没有提供任何参数,则自动注册 autoload 的默认实现函数spl_autoload()。
throw:
此参数设置了autoload_function
无法成功注册时, spl_autoload_register()是否抛出异常。
prepend:
如果是 true,spl_autoload_register() 会添加函数到队列之首,而不是队列尾部。
3.psr4
1.此处的“类”泛指所有的class类、接口、traits可复用代码块以及其它类似结构。
2.一个完整的类名需具有以下结构:
<命名空间>(<子命名空间>)*<类名>
1)完整的类名必须要有一个顶级命名空间,被称为 "vendor namespace";
2)完整的类名可以有一个或多个子命名空间;
3)完整的类名必须有一个最终的类名;
4)完整的类名中任意一部分中的下滑线都是没有特殊含义的;
5)完整的类名可以由任意大小写字母组成;
6)所有类名都必须是大小写敏感的。
3.当根据完整的类名载入相应的文件……
1)完整的类名中,去掉最前面的命名空间分隔符,前面连续的一个或多个命名空间和子命名空间,作为“命名空间前缀”,其必须与至少一个“文件基目录”相对应;
2)紧接命名空间前缀后的子命名空间必须与相应的”文件基目录“相匹配,其中的命名空间分隔符将作为目录分隔符。
3)末尾的类名必须与对应的以 .php 为后缀的文件同名。
4)自动加载器(autoloader)的实现一定不能抛出异常、一定不能触发任一级别的错误信息以及不应该有返回值
使用PSR4,有2个好处:1. 减少代码目录的深度;2. 可以通过前缀快速找到映射目录,提高自动加载的效率
ps:psr0与psr4主要区别:1.psr0比4多了 一条类名的_下划线转换成目录。2.psr4比0多了一个 命名空间前缀和目录的替换关系 当加载类的时候类名空间指定的前缀会被替换成路径再加上后面的子空间和类名 构成实际加载地址。而0没有这个对应关系。命名空间直接转换为目录再加上指定的目录前缀构成实际的加载地址。
4.yii2
index.php
require($_SERVER['ENV_FRAMEWORK_DIR'] . 'autoload.php');//yii2的自动加载文件
require($_SERVER['ENV_FRAMEWORK_DIR'] . 'yiisoft/yii2/Yii.php');
require(__DIR__ . '/../common/config/bootstrap.php');
$config = require(__DIR__ . '/../ordinary/config/main.php');
autoload.php
require_once __DIR__ . '/composer' . '/autoload_real.php';
return ComposerAutoloaderInitcf708c3c6363e39b2b6c83d3e69ad060::getLoader();
autoload_real.php
spl_autoload_register(array('ComposerAutoloaderInitcf708c3c6363e39b2b6c83d3e69ad060', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader();
spl_autoload_unregister(array('ComposerAutoloaderInitcf708c3c6363e39b2b6c83d3e69ad060', 'loadClassLoader'));
$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);
}
ClassLoader.php
// PSR-4 lookup
$logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext;
$first = $class[0];
if (isset($this->prefixLengthsPsr4[$first])) {
foreach ($this->prefixLengthsPsr4[$first] as $prefix => $length) {
if (0 === strpos($class, $prefix)) {
foreach ($this->prefixDirsPsr4[$prefix] as $dir) {
if (is_file($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) {
return $file;
}
}
}
}
}
// PSR-4 fallback dirs
foreach ($this->fallbackDirsPsr4 as $dir) {
if (is_file($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) {
return $file;
}
}
yii2 通过require加载自身的autoload.php文件,导入autoload_real.php,这个文件将文件autoload_classmap.php,autoload_files,autoload_namespaces.php,autoload_psr4.php注入到类Classloader中,ClassLoader通过psr-4,namaspace,files(直接require),classmap(类名=>文件所在路径)四种方式来加载文件,顺序依次是判断classmap中有没有这个类,有直接require他的文件路径,然后根据psr4规则拼接路径寻找文件,最后根据psr0规则拼接路径寻找文件,