php自动加载机制原理分析,php类的自动加载

发布时间:2022-11-23

本文目录一览:

  1. 请简述php的autoload机制是什么,有哪些实现方式
  2. Composer 自动加载原理
  3. php 命名空间是怎么自动加载的
  4. php,thinkphp自动加载怎么实现的呢?
  5. 详解PHP文件的自动加载(autoloading)
  6. PHP自动加载原理是什么,感觉还是老老实实写require好

请简述php的autoload机制是什么,有哪些实现方式

这个是类的自动加载。魔术方法,你声明一个类,这个类你要用到其他类不用把其他类文件包含过来,当年实例化要用到类的时候,这个类就会被自动加载过来(类名字),autoload有个参数,你输出一下就得到你实例化的那个类名,然后你拼好这个类文件名,在里面再require一下。就可以用了。

Composer 自动加载原理

到达 composer 工作区 实现自动加载的过程可简单分为三步: 下面演示 laravel 四种声明加载标准的组件,是如何归纳的。 文件预加载,框架启动时便被 include,通常文件中提供一些函数方法方便我们使用,如经常用的 dd()"files":["src/Illuminate/Foundation/helpers.php"]" 写入 /composer/autoload_files.php, 直接映射文件真实路径。这是简单粗暴的,因此这种方式效率是最高的。 "classmap": ["hamcrest"],写入 /composer/autoload_classmap.phpuse Hamcrest\Arrays\IsArray; 时,可直接在 classmap 的数组中找到它,是不是很粗暴呢。 这是最常用的加载标准。"psr-4": {"App\\": "app/"} 写入 autoload_psr4.php 只要是 app/ 目录下的文件,且命名空间符合 psr-4 标准的类文件都能被自动加载。如 use App\Test = app/Test.php。而 classmap 方式不可以,这样你可以在 app/ 下自由的增加 / 删除类文件了。 这里提一下,前面说 classmap 方式是最高效的,而 composer dump-autoload 可以将通过 psr-4 规范加载的文件 “落盘”,即写入 autoload_classmap.php。从而起到加速的作用,官方建议生产环境时执行 composer dump-autoload --optimize 来优化项目的自动加载速度。 为了说明 composer dump-autoload 的作用,我在 app 目录下建立 Test.php 执行 composer dump-autoload 后,发现在 autoload_classmap.phpautoload_static.php(稍后再提及)中找到了它。 而 composer dump-autoload --optimize 的作用是进行优化(optimize),清理无效索引空间另外在 /composer 生成了 user 缓存文件。 和 psr-4 类似,只是加载规则有所不同。官方已弃用,但 laravel 有的组建包还是在用的,composer 仍然支持向下兼容。"psr-0": {"Mockery": "library/"} 写入 autoload_namespaces.php。 注:autoload_static.php 它包含了四个文件的全部映射,是为了精简篇幅这里不做介绍了。

php 命名空间是怎么自动加载的

实现自动加载最简单的方式就是使用 __autoload 魔术方法。当需要使用的类没有被引入时,这个函数会在PHP报错前被触发,未定义的类名会被当作参数传入。至于函数具体的逻辑,这需要用户自己去实现。

php,thinkphp自动加载怎么实现的呢?

php 中有个魔术方法 __autoload,这个函数在找不到类的时候就会调用,自动加载就是在这里实现的。通过指定自动加载类的路径,只要保证文件名和类名一样。就可以自动加载。这也是为什么你看很多源码中类的名字和文件名一样的原因,这样可以实现自动加载,不需要 include

详解PHP文件的自动加载(autoloading)

传统上,在PHP里,当我们要用到一个class文件的时候,我们都得在文档头部 require 或者 include 一下:

<?php
require_once('../includes/functions.php');
require_once('../includes/database.php');
require_once('../includes/user.php');
...

但是一旦要调用的文档多了,就得每次都写一行,瞅着也不美观,有什么办法能让PHP文档自动加载呢?

<?php
function __autoload($class_name) {
    require "./{$class_name}.php";
}

对,可以使用PHP的魔法函数 __autoload(),上面的示例就是自动加载当前目录下的PHP文件。当然,实际当中,我们更可能会这么来使用:

<?php
function __autoload($class_name) {
    $name = strtolower($class_name);
    $path = "../includes/{$name}.php";
    if(file_exists($path)) {
        require_once($path);
    } else {
        die("the file {$class_name} could not be found");
    }
}

也即是做了一定的文件名大小写处理,然后在 require 之前检查文件是否存在,不存在的话显示自定义的信息。 类似用法经常在私人项目,或者说是单一项目的框架中见到,为什么呢?因为你只能定义一个 __autoload 函数,在多人开发中,做不到不同的 developer 使用不同的自定义的 autoloader,除非大家都提前说好了,都使用一个 __autoload,涉及到改动了就进行版本同步,这很麻烦。 也主要是因为此,有个好消息,就是这个 __autoload 函数马上要在7.2版本的PHP中弃用了。

Warning This feature has been DEPRECATED as of PHP 7.2.0. Relying on this feature is highly discouraged. 那么取而代之的是一个叫 spl_autoload_register() 的东东,它的好处是可以自定义多个 autoloader。

// 使用匿名函数来 autoload
spl_autoload_register(function($class_name) {
    require_once('...');
});
// 使用一个全局函数
function Custom() {
    require_once('...');
}
spl_autoload_register('Custom');
// 使用一个 class 当中的 static 方法
class MyCustomAutoloader {
    static public function myLoader($class_name) {
        require_once('...');
    }
}
// 传 array 进来,第一个是 class 名,第二个是方法名
spl_autoload_register(['MyCustomAutoloader','myLoader']);
// 甚至也可以用在实例化的 object 上
class MyCustomAutoloader {
    public function myLoader($class_name) {
    }
}
$object = new MyCustomAutoloader;
spl_autoload_register([$object,'myLoader']);

值得一提的是,使用 autoload,无论是 __autoload(),还是 spl_autoload_register(),相比于 requireinclude,好处就是 autoload 机制是 lazy loading,也即是并不是你一运行就给你调用所有的那些文件,而是只有你用到了哪个,比如说 new 了哪个文件以后,才会通过 autoload 机制去加载相应文件。 当然,laravel 包括各个 package 里也是经常用到 spl_autoload_register,比如这里:

/**
 * Prepend the load method to the auto-loader stack.
 *
 * @return void
 */
protected function prependToLoaderStack() {
    spl_autoload_register([$this, 'load'], true, true);
}

PHP自动加载原理是什么,感觉还是老老实实写require好

spl 函数,自己注册一个 spl_autoload_register,然后在找不到这个类的时候,执行这个函数,然后这个函数根据你的文件规则,找到相应的文件,然后 require,然后就可以了。