[Android组件解读] EventBus3.0解析
记得前段时间讲解过otto事件总线的概念,但是大家习惯用的事件总线应该还是EventBus。
EventBus介绍
EventBus is a publish/subscribe event bus optimized for Android.
EventBus...
- simplifies the communication between components
- decouples event senders and receivers
- performs well with Activities, Fragments, and background threads
- avoids complex and error-prone dependencies and life cycle issues
- makes your code simpler
- is fast
- is tiny (~50k jar)
- is proven in practice by apps with 100,000,000+ installs
- has advanced features like delivery threads, subscriber priorities, etc.
简单点说:解决了以前各个业务逻辑的嵌套,让代码更加简洁
1.更好的处理组件/线程间的事件传递
2.使用起来更加快捷
3.代替了原来的Intent,Handler,BroadCast
最新的EventBus已经到3.0
关于EventBus2.x与3.x区别
1.Eventbus3.x支持粘性传递
2.不需要再写onEvent,onMainEvent。可以随意定义方法名字
3.他们不兼容的,eventbus2.x包名:de.greenrobot.eventbus.EventBus,3.x的包名:org.greenrobot.eventbus.EventBus
具体可以这篇文章
Eventbus2.x与3.x的区别
关于EventBus与otto的区别
1.Otto发送的时候需要register和unregister,而Eventbus需要
2.Otto使用的是@Subcribe,而Eventbus2.x使用的是onEvent,onMainEvent,但是Eventbus3.x使用的跟Otto差不多
具体可以看这篇文章
Eventbus & otto
使用姿势
这里拿Eventbus3.x进行说明了,至于Eventbus2.x介绍可以看这篇Eventbus2.x使用
-
build.gradle注册EventBus
// evnetbus使用 compile 'org.greenrobot:eventbus:3.0.0'
-
注册与注销EventBus
@Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); EventBus.getDefault().register(this); } ... @Override protected void onDestroy() { super.onDestroy(); EventBus.getDefault().unregister(this); }
-
接受Event事件,此处就是3.x与2.x的区别。
关于Subscribe的参数,末尾会介绍这个
@Subscribe(threadMode = ThreadMode.MAIN,sticky = false, priority = 0) public void testEventBus(MyEvent myEvent){ Log.d("test",myEvent.getEvent()); }
-
新建事件,并进行发送
public enum MyEvent { DEFAULT("default"); private String event; MyEvent(String event){ this.event = event; } public String getEvent() { return event; } } // 发送Event EventBus.getDefault().post(MyEvent.DEFAULT);
到此调用方式就结束了。
Subscribe的介绍
-
ThreadMode:这是个枚举,有四个值,决定订阅函数在哪个线程执行
- PostThread:事件发送者在哪个线程就执行在哪个线程。同2.x中的onEvent方法,默认值就是这个
- MainThread:订阅函数一定执行在主线程。同onEventMainThread方法
- BackgroundThread:如果是事件从子线程发出,订阅函数就执行在那个子线程,不会创建新的子线程;如果主线程发出事件,则创建子线程。同onEventBackgroundThread方法
- Async:一定创建子线程。同onEventAsync方法。
-
sticky:默认为false,如果为true,当通过postSticky发送一个事件时,这个类型的事件的最后一次事件会被缓存起来,当有订阅者注册时,会把之前缓存起来的这个事件直接发送给它。使用在比如事件发送者先启动了,订阅者还没启动的情况。
-
priority:默认值为0。订阅了同一个事件的订阅函数,在ThreadMode值相同的前提下,收到事件的优先级。
关于如何实现?
与otto的实现方式几乎一致
register:将注册的对象放入到List,并遍历它的有@Subcribe的方法,将这些方法进行缓存。
post:执行的时候,查找跟它的参数一致的@Subcribe的方法,通过invoke方法进行反射执行
unregister:将对象销毁
其实3.0的实现跟otto几乎一致
相比2.0是通过遍历onEvent,onMainEvent来进行方法缓存,通过@Subcribe更加简单
git地址:https://github.com/greenrobot/EventBus.git
看代码发现,最新的greenrobot的组件的报名都从‘de.greenrobot’ 改为 ‘org.greenrobot’,可以看下GreenDao和Eventbus.这说明了,升到最新的版本老版本就不兼容了。