基于Agera的EventBus实现库2-添加多进程支持

AgeraBus简介

AgeraBus 是基于谷歌开源的Agera实现的Android事件总线,实现了EventBus基本常用的功能,下面将为你一一介绍,如果要了解Agera,可以去看我文章后面推荐的两个地址。

添加依赖

在项目根目录的build.gradle中添加:

dependencies {
    compile 'xyz.zpayh:agerabus:1.0.4'
    compile 'com.google.android.agera:agera:1.3.0'
}

基本使用方法

单进程下的基本使用方法可以参考我之前写的文章
基于Agera的EventBus实现库

多进程支持

一般来讲,EventBus只支持单进程下传递事件的,因为使用多进程都会造成如下几个方面的问题:

  • 静态成员和单例模式完全失效。
  • 线程同步机制失效。
  • Application会多次创建。

造成上面问题的原因是因为不同进程间不共享内存,而Application是因为每个进程初始化过程都会创建新的Application。不同进程的组件会拥有独立的虚拟机、Application、以及内存空间,这就使得事件传递不了,使EventBus失效。

AgeraBus 采用Messenger实现跨进程通信,相比于之前的使用方法有些许不一样:

  • 在自己的Application的onCreate中调用AgeraBus.init(Context)进行注册(由于Application在每个进程都会被创建,确保了每个进程都有向AgeraBus进行注册,如果不在Application进行注册的话,就在各个不同进程的组件第一次使用的时候进行注册也行);
  • 跨进程传递的事件必须实现Serializable或者Parcelable接口(基本类型已经默认实现Serializable)。
  • 没了,其他使用方法跟基于Agera的EventBus实现库一样。

注意

多进程有些限制:

  • 没有实现Serializable或者Parcelable接口的事件是不会跨进程传递的。
  • 由于跨进程不能共享内存的,本质上事件在跨进程传递中已经不是同一个事件了,所以不同进程对事件内容进行修改,是不会对其他进程造成影响的,除非你重新发送新事件。
  • 取消事件的传递也只对当前进程有效,没法影响到其他进程。

v1.0.3版本中除了实现了IPC传递事件之外,也更新到Agera最新版本,还有就是取消事件传递必须在发送事件的线程中取消,否则是没有效果的,本来是想抛出运行时异常,想想还是算了。

以上就是AgeraBus的最新版本的使用,具体使用方法可以看Github上的SampleDemo,下面放出链接,希望有在学习使用Agera的同学也能使用我的AgeraBus。

AgeraBus

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,773评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,835评论 25 709
  • Jianwei's blog 首页 分类 关于 归档 标签 巧用Android多进程,微信,微博等主流App都在用...
    justCode_阅读 11,194评论 1 23
  • 1.不要愁老之将至,你老了一定很可爱。而且,假如你老了十岁,我当然也同样老了十岁,世界也老了十岁,上帝也老了十岁,...
    城市崛起阅读 1,820评论 0 0
  • 先说一说为什么讲网贷的最好时代即将开始。 现在提到网贷/p2p几乎就如过街老鼠,人人痛打,比如说我写一篇推荐网贷的...
    小生爱财阅读 2,934评论 2 2