[Android组件解读] EventBus3.0解析

记得前段时间讲解过otto事件总线的概念,但是大家习惯用的事件总线应该还是EventBus。

EventBus介绍

EventBus is a publish/subscribe event bus optimized for Android.

[Android组件解读] EventBus3.0解析_第1张图片

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.

上面是github上EventBus的介绍

简单点说:解决了以前各个业务逻辑的嵌套,让代码更加简洁

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使用

  1. build.gradle注册EventBus

    // evnetbus使用
    compile 'org.greenrobot:eventbus:3.0.0'
    
  2. 注册与注销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);
    }
    
  3. 接受Event事件,此处就是3.x与2.x的区别。关于Subscribe的参数,末尾会介绍这个

    @Subscribe(threadMode = ThreadMode.MAIN,sticky = false, priority = 0)
    public void testEventBus(MyEvent myEvent){
        Log.d("test",myEvent.getEvent());
    }
    
  4. 新建事件,并进行发送

    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.这说明了,升到最新的版本老版本就不兼容了。

参考资料

Eventbus2.x使用

Eventbus3.x使用

你可能感兴趣的:([Android组件解读] EventBus3.0解析)