EventBus事件通知的框架我们用了很久了,随着LiveData的出现,出现了LiveDataBus来替代EventBus,因为LiveDataBus 会考虑生命周期,EventBus你可能要注意在生命周期结束的时候unregister的,否则会有内存泄漏等问题,而LiveDataBus 会在生命周期中自动清理 ,和jetpack大家族一脉相承,随着我们整个应用开始对jetpack化,这是一个趋势。LiveDataBus 是对LiveData的封装,很多小伙伴自己封装来用,但有时候会考虑不周,github上star最多的LiveData框架就是LiveDataBus了,下面我们就一起分析一下这个库的源码:
我们先看看使用的代码如下:很简单,post是发送数据,observe是接收数据,with来定义类型,赛道,使得数据一一对应上。
然后我们看看get方法的源码,实际是调用了LiveDataBusCore的with方法。
注意,我们发送消息和接收消息都是调用了get方法,也就是下面的with方法,看看,这里可是get set方法集成到一起的,就很怪,作者这里弄的,讲道理,不符合单一职责。
还有一个需要注意的地方泛型 ,发现没有上图没用到type这个参数 而item放进map里面的<>泛型是根据前面来推算的
那我们接着说,那整个的精华就是这个bus 的map了,key是string的 ,value是LiveEvent 的,看下图一个LiveEvent是有一个livedata来负责观察的,也就是多个消息的时候就是多个livedata,然后是bus这个map在管理。
这个思路就是这样的,数据消息发送了变化由它对应的livedata来负责通知观察者做响应的操作也就是消息的响应。