关于laravel:Laravel底层学习笔记04-加载并启动ServiceProvider事件观察者模式

参考资料:
Laravel Service Provider 中 boot 办法和 register 办法的区别
php artisan 命令

new self 和new static

new self() 返回的是self所在类
new static() 返回调用者所在类

class Father{
    public function getSelf(){
        return new self();
    }
    public function getStatic(){
        return new static();
    }
}
$f = new Father();
echo get_class($f->getSelf());//Father
echo get_class($f->getStatic());//Father
class Son extends Father{
}
$s = new Son();
echo get_class($s->getSelf());//Father
echo get_class($s->getStatic());//Son

加载并启动ServiceProvider

boot和register办法的区别

register办法是必须的,boot办法不是

register 办法用于绑定服务到容器,框架会先调用所有 provider 的 register 办法,等所有服务都注册结束再去调用每一个服务的 boot 办法。

所以不能在 register 办法外面调用其余 provider 提供的服务,因为咱们无奈保障其余服务曾经注册结束。

而在 boot 办法外面你能够干任何事件!

dispatch和提早加载

提早加载

开启提早加载

vim FamilyServiceProvider.php

$defer = true;

public function providers(){
    return ['Family'];
}

除编译生成的文件(optimize的反向操作)

php artisan clear-compiled

调用

app('Family')->test();

//没有providers()时的调用办法
app('App\Service\Family\FamilyService')->test();
//providers()办法等价于
app('app')->bind('Family','App\Service\Family\FamilyService');

源码

vim Illuminate/Foundation/Application.php

public function make($abstract, array $parameters = [])
{
    $abstract = $this->getAlias($abstract);
    if (isset($this->deferredServices[$abstract]) && ! isset($this->instances[$abstract])) {
        $this->loadDeferredProvider($abstract);
    }
}

事件和监听者

观察者模式

观察者模式可能便当的创立查看指标对象状态的对象,并且提供与外围对象非耦合的指定性功能。

为软件增加由某个动作或状态变动激活的,然而涣散耦合的新性能时,该当创立基于观察者模式的对象。

模仿创立订单时发送短信邮件

非观察者模式
class order{
    public function add(){
        $a = new Message();$a->send();
        $b = new Email();$b->send();
    }
}
class Message{
    public function send(){
        echo '发送短信';
    }
}
class Email{
    public function send(){
        echo '发送邮件';
    }
}
$order = new Order();
$order->add();//发送短信发送邮件
观察者模式
<?php
//被观察者接口
interface Observable{
    function add(Observe $observe);//新增观察者
    function del(Observe $observe);//删除观察者
}
class order implements Observable{
    private $instance = array();
    public function add(Observe $observe){
        if(array_search($observe, $this->instance) === false){
            $this->instance[] = $observe;
        }
    }
    public function del(Observe $observe){
        if($key = array_search($observe, $this->instance) !== false){
            unset($this->instance[$key]);
        }
    }
    public function notify(){
        foreach ($this->instance as $observe){
            $observe->send();
        }
    }
}
//观察者
interface Observe{
    function send();
}
class Message implements Observe{
    public function send(){
        echo '发送短信';
    }
}
class Email implements Observe{
    public function send(){
        echo '发送邮件';
    }
}
$order = new Order();
$order->add(new Message());
$order->add(new Email());
$order->notify();//发送短信发送邮件

如果再想发送钉钉揭示,则只须要实现Observe接口类即可

class DingTalk implements Observe{
    public function send(){
        echo '发送钉钉揭示';
    }
}
$order = new Order();
$order->add(new DingTalk());
$order->notify();//发送钉钉揭示

创立事件和监听者

创立事件和监听者

php artisan make:event EventTest
php artisan make:listener EventTestListener
php artisan make:listener OtherListener

注册事件和监听者

vim app/Providers/EventServiceProvider.php

'App\Events\EventTest' => [
    'App\Listeners\EventListener',
    'App\Listeners\OtherListener',
],

调用事件

event(new EventTest());

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理