美文网首页Android技术知识
探究EventBus粘性事件实现机制

探究EventBus粘性事件实现机制

作者: 搬砖小老弟 | 来源:发表于2022-05-30 16:31 被阅读0次

作者:长安皈故里
转载地址:https://juejin.cn/post/7102815596621856799

众所周知,EventBus是支持粘性事件的,即可以先发送粘性事件,然后再注册,代码如下:

  1. 粘性事件观察者
@Subscribe(threadMode = ThreadMode.MAIN, sticky = true)
fun registerEventBus(o: Any) {    
}
  1. 发送粘性事件
EventBus.getDefault().postSticky(Any())
  1. 注册EventBus
EventBus.getDefault().register(this)

接下来我们就来探究下EventBus的粘性事件是如何实现的。

postSticky()内部机制

  1. 如果是发送的粘性事件,会添加到stickyEvents中,看下这个属性的实现:

可以看到这个属性是一个Map集合,其中key为事件类型的class对象,value为对应的事件类型。

  1. 继续看下post(Event)方法:
  1. 首先将这个粘性事件添加到PostingThreadState(线程私有)的eventQueue集合中

  2. 通过isMainThread方法判断当前是否为主线程,最终会调用到我们熟悉的Looper.getMainLooper() == Looper.myLooper()进行判断

  3. 循环遍历eventQueue队列,不断的取出集合元素进行分发,看下postSinleEvent()方法如何实现:

  1. 如果eventInheritance为true,会查找当前发送的粘性事件类型的父类型,并返回查找到的集合

  2. 接下来就会调用postSingleEventForEventType()方法来进行最终粘性事件的分发,即通知通过@Subscribe注解注册的粘性事件观察者,看下具体实现:

  1. 调用subscriptionsByEventType获取注册该事件类型的所有订阅方法,但是由于这个时候我们是先发送的粘性事件再注册EventBus,而subscriptionsByEventType中集合元素的填充实在注册EventBus发生的,所以通过subscriptionsByEventType获取到的subscriptions将是null的,所以接下来肯定不会走下面的if代码块中的逻辑了。

postSticky()小结

上面这么多代码逻辑,其实只干了一件事,就是将这个粘性事件添加到了stickyEvents这个集合中。之后的逻辑虽多,但和粘性事件没啥关系。

register内部机制

  1. findSubscriberMethods()这个方法里面的逻辑就不带大家进行分析了,总之就干了一件事情:

查找当前类通过@Subscribe注册的所有事件订阅方法,并返回一个List<SubscriberMethod>集合,其中SubscriberMethod就是对每个注册的订阅方法和当前注册类的封装

  1. subscribe这个方法是关键,深入探究下:
  • 第1、2、3、4步中其实就干了两件事情:

    • 填充subscriptionsByEventType集合,key为事件类型,value为通过@Subscribe订阅了该事件类型的方法集合
    • 填充typesBySubscriber集合,key为注册EventBus的类,value为该类中所有@Subscribe注解修饰的方法集合
  • 第5步就是实现粘性事件分发的关键地方

    • 首先判断当前@Subscribe修饰的订阅方法是否为粘性,即@Subscribe(sticky = true)sticky等于true
    • 是的话就从stickyEvents集合中判断是否存在和订阅方法中注册的事件类型相同的事件:

    这个stickyEvents是不是很熟悉,就是我们之前发送粘性事件时,将粘性事件添加到的方法集合

    • 如果存在,则就执行该粘性事件的分发,即调用执行该订阅方法,最终会调用到invokeSubscriber()方法:

从上面可以看到,最终是通过反射来实现的订阅了粘性事件方法的执行。

register小结

该方法最终会判断当前是否存在注册EventBus前发送的粘性事件,且当前注册类中存在订阅该事件类型的方法,然后立即执行。

总结

以上就是EventBus粘性事件的内部实现机制,总体来说不算复杂,大家看着文章跟着源码一步步分析应该就很容易理解这部分实现逻辑了。

相关文章

  • Android EventBus粘性事件实现机制探究

    Android EventBus粘性事件实现机制探究 众所周知,eventbus是支持粘性事件的,即可以先发送粘性...

  • 探究EventBus粘性事件实现机制

    作者:长安皈故里转载地址:https://juejin.cn/post/7102815596621856799[h...

  • EventBus3.0源码分析

    本文分为以下几个部分:创建、注册、发送事件、粘性事件来讲解它的实现原理,本文使用Eventbus版本为3.1.1。...

  • EventBus全解析系列(五)

    EventBus 源代码分析-你不知道的EventBus小环节 1.STICKY 粘性事件 在EventBus中有...

  • eventBus粘性事件

    因为请求接口然后再发送事件再进行控件的更新。有时候该控件所在的页面可能没有初始化好。这时候eventbus所发送的...

  • EventBus 简单使用(二)

    EventBus 简单使用(一) 日更 14 天。 本文主要介绍以下两个知识点,重点是 粘性事件 粘性事件 混淆 ...

  • 手把手debug源码之EventBus

    本文基于EventBus3.1.1进行源码分析,以发送一个正常事件和粘性事件为例,探索EventBus工作的整个过...

  • EventBus框架初解

    EventBus其实解决了这样几个问题:保存订阅者、发布事件、切换线程、粘性事件 保存订阅者 在register(...

  • EventBus3.0使用(二)

    上一篇EventBus3.0使用(一) Sticky Events 粘性事件 Sticky Events可以允许事...

  • EventBus源码解析

    知识点汇总: 一:EventBus框架概述 二:EventBus的注册实现原理 三:EventBus的事件分发实现...

网友评论

    本文标题:探究EventBus粘性事件实现机制

    本文链接:https://www.haomeiwen.com/subject/rvioprtx.html