Maison >développement back-end >tutoriel php >Laravel 5.5) Méthode de chargement de l'instance de processus

Laravel 5.5) Méthode de chargement de l'instance de processus

PHP中文网
PHP中文网original
2018-02-18 14:04:454304parcourir

Instancier la classe supplier/laravel/framework/src/Illuminate/Foundation/Application.php dans bootstrap/app.php

/**
 * 对于其中的instance register singleton 方法到时候单独拎出来说明
 * 
 * 1.设置基础路径
 * 2.使用instance 方法 绑定app 和Illuminate\Foundation\Application类的关系
 * 3.使用instance 方法 绑定Container 和Illuminate\Foundation\Application类的关系
 * 4.app变量中注册事件服务EventServiceProvider
 * 5.app变量中注册日志服务LogServiceProvider
 * 6.app变量中注册路由服务RoutingServiceProvider
 * 7.别名的注册(vendor/laravel/framework/src/Illuminate/Foundation/Application.php文件中的 registerCoreContainerAliases 方法) */$app = new Illuminate\Foundation\Application(    realpath(__DIR__.'/../')
);

La magie méthode

    public function __construct($basePath = null)
    {        /**
         * 如果有传地址  设置基础路径 设置 
         * path                 $this->path()
         * path.base              $this->basePath()
         * path.lang             $this->langPath()
         * path.config             $this->configPath()
         * path.public            $this->publicPath()
         * path.storage            $this->storagePath()
         * path.database        $this->databasePath()
         * path.resources        $this->resourcePath()
         * path.bootstrap         $this->bootstrapPath()         */
        if ($basePath) {            $this->setBasePath($basePath);
        }        /**
         * 注册 app 和container到 instances数组中         */
        $this->registerBaseBindings();        /**
         * 注册EventServiceProvider LogServiceProvider  RoutingServiceProvider         */
        $this->registerBaseServiceProviders();        /**
         * 设置核心类的别名         */
        $this->registerCoreContainerAliases();
    }

Afficher l'application et le conteneur enregistrés dans le tableau des instances

    protected function registerBaseBindings()
    {        static::setInstance($this);        /**
         * 由于初始化中  app没有添加到instances数组中 所以 不会执行build函数  只做了 instances数组中记录了app和$this         */
        $this->instance('app', $this);        /**
         * 由于初始化中  Container没有添加到instances数组中 所以 不会执行build函数 只做了 instances数组中记录了app和$this         */
        $this->instance(Container::class, $this);
    }


Afficher l'instance principale des méthodes d'aujourd'hui

Organigramme

 public function instance($abstract, $instance)
    {        /**
         * 如果aliases 数组总存在  则游离abstractAliases 数组  删除其中的存在的值         */
        $this->removeAbstractAlias($abstract);        /**
         * 判断  在bindings aliases instances其中有一个存现  则返回true         */
        $isBound = $this->bound($abstract);        /**
         * 删除别名数组中对于的建         */
        unset($this->aliases[$abstract]);        // We'll check to determine if this type has been bound before, and if it has
        // we will fire the rebound callbacks registered with the container and it
        // can be updated with consuming classes that have gotten resolved here.
        /**
         * 在instances 数组中添加对于的建         */
        $this->instances[$abstract] = $instance;        /**
         * 如果之前存在实例化 则运行         */
        if ($isBound) {            $this->rebound($abstract);
        }
    }

La première méthode RemoveAbstractAlias

    /**
     * Remove an alias from the contextual binding alias cache.
     *
     * @param  string  $searched
     * @return void     */
    protected function removeAbstractAlias($searched)
    {        /**
         * 如果在别名数组中不存在则直接返回         */
        if (! isset($this->aliases[$searched])) {            return;
        }        /**
         * 游离抽象别名 吧存在抽象类别名数组中的存在的删除
         * @example abstractAliases = ['nameabstract'=>['aliase1','aliases2']]         */
        foreach ($this->abstractAliases as $abstract => $aliases) {            foreach ($aliases as $index => $alias) {                if ($alias == $searched) {                    unset($this->abstractAliases[$abstract][$index]);
                }
            }
        }
    }

La deuxième méthode : lié

    /**
     * Determine if the given abstract type has been bound.
     *
     * @param  string  $abstract
     * @return bool     */
    public function bound($abstract)
    {        return isset($this->bindings[$abstract]) ||               isset($this->instances[$abstract]) ||               $this->isAlias($abstract);
    }

La troisième méthode : rebond

 /**
     * Fire the "rebound" callbacks for the given abstract type.
     *
     * @param  string  $abstract
     * @return void     */
    protected function rebound($abstract)
    {        /**
         * 主要实现的功能为 build 方法 实例化制定的类 并且返回该类 
         */
        $instance = $this->make($abstract);        /**
         * 查看reboundCallbacks 数组中是否存在该别名创建完成之后需要调用的方法数组 
         * 存在返回需要调用的方法数组   并且逐个执行         */
        foreach ($this->getReboundCallbacks($abstract) as $callback) {            call_user_func($callback, $this, $instance);
        }
    }

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn