官方给的
tutorial
完全把我搞混了,command bus queue的例子中使用了event事件,而event事件中又有事件队列。然后小白搞不懂两者区别了,最后结论么,两者根本没关系。
event事件其实就是观察者模式的实现,简单来说先定义一个事件,然后定义1个或多个监听器来监听这个事件,一旦事件发生,监听器都会做出相应的逻辑处理。比如有个事件发生:股票涨了,有2个监听器(分别是媒体,股民)都立即做出反应,媒体立马发布股票涨了的新闻,股民立马抛售或增持。
具体实现是:
在EventServiceProvider中注册监听事件和监听器,又看到service provider了,看下它源码:
请忽略我给register写的注释,EventSevericeProvider在该方法中没有相应逻辑,我只是突然想到了其他ServiceProvider有用到该方法所以写了点笔记。
另外,还有2个概念我当初有点搞混,既然可以绑定多个监听器到一个监听时间上,那还搞个事件订阅者干什么。后来看看官网给的
UserEventListener的例子,想想应该是这么回事。
比如用户登录、登出其实都是用户的行为,假设使用$listen数组去注册的话,就要写2个监听器类,代码太冗余,但用事件订阅者,就只要写一个类,最后把用户行为在
subscribe方法中统一绑定,看源码就发现注册形式和写在$listen数组的格式差不多,
而$listen数组是这样的,
证实了我之前的猜想,如果写在$listen数组中就要写2遍了。
最后关于事件队列(queue),事件分发器Dispatcher有两种处理方式,
1)sync方式,顾名思义,监听器多或者监听器执行事件长,会造成阻塞
2)push到队列中,由background执行
2)push到队列中,由background执行