EventBus

作者: 好记性不如烂Bettle | 来源:发表于2018-02-13 13:29 被阅读1次

    EventBus的使用

    GitHub地址

    添加依赖

    compile 'org.greenrobot:eventbus:3.1.1'

    快速开始:三步使用EventBus

    Step 1: 定义事件(事件是一个实体类)

    public class MessageEvent {
        public final String message;
        public MessageEvent(String message) {
            this.message = message;
        }
    }
    

    Step 2: 提供订阅者

    通过添加@Subscribe注解来定义一个订阅者:

    // This method will be called when a MessageEvent is posted (in the UI thread for Toast)
    @Subscribe(threadMode = ThreadMode.MAIN)
    public void onMessageEvent(MessageEvent event) {
        Toast.makeText(getActivity(), event.message, Toast.LENGTH_SHORT).show();
    }
    

    订阅者需要进行注册和反注册:

    //In Android, in activities and fragments you should usually register according to their life cycle.For most cases onStart/onStop works fine:
    @Override
    public void onStart() {
        super.onStart();
        EventBus.getDefault().register(this);
    }
    
    @Override
    public void onStop() {
        EventBus.getDefault().unregister(this);
        super.onStop();
    }
    

    Step 3: 发送事件

    你可以在任何地方发送你的事件,当前已经注册的订阅者,只要接受事件类型和发送事件的类型相匹配就可以接受到.

    EventBus.getDefault().post(new MessageEvent("Hello everyone!"));
    

    EventBus的五种线程模式

    1.POSTING:

    默认线程模式,订阅者的调用和发送事件是在同一个线程,由于不经过线程的切换,使用这种线程模式实现了最小的开支.对于那些任务量比较小,且不在主线程执行的任务,是比较推荐的.如果在主线程,要避免耗时过长阻塞主线程.

    // Called in the same thread (default)
    // ThreadMode is optional here
    @Subscribe(threadMode = ThreadMode.POSTING)
    public void onMessage(MessageEvent event) {
        log(event.message);
    }
    

    2. MAIN:

    这种模式的订阅者在UI线程中调用.如果发送事件的调用也是在主线程,
    那么这种模式就和POSTING模式一样.

    // Called in Android UI's main thread
    @Subscribe(threadMode = ThreadMode.MAIN)
    public void onMessage(MessageEvent event) {
        textField.setText(event.message);
    }
    

    3. MAIN_ORDERED:

    这种模式的订阅者也是在UI线程中调用.与Main不同的是,订阅者执行事件的顺序是有序的,第二的事件的执行必须等到第一件事件处理完成后才能得到执行.

    // Called in Android UI's main thread
    @Subscribe(threadMode = ThreadMode.MAIN_ORDERED)
    public void onMessage(MessageEvent event) {
        textField.setText(event.message);
    }
    

    4. BACKGROUND:

    这种模式的订阅者在子线程进行调用.如果事件的发送在子线程,订阅也会在该子线程中进行回调.如果时间发送是在主线程,那么EventBus会创建一个单独的子线程来进行回调订阅者.

    // Called in the background thread
    @Subscribe(threadMode = ThreadMode.BACKGROUND)
    public void onMessage(MessageEvent event){
        saveToDisk(event.message);
    }
    

    5. ASYNC:

    这种模式下,EventBus会创建一个独立的子线程来进行订阅者回调.用来处理需要进行耗时操作的任务,EventBus通过创建线程池来高效的重用线程.

    // Called in a separate thread
    @Subscribe(threadMode = ThreadMode.ASYNC)
    public void onMessage(MessageEvent event){
        backend.send(event.message);
    }
    

    未完待续....

    相关文章

      网友评论

        本文标题:EventBus

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