EventBus

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)