EventBus的使用
添加依赖
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);
}
网友评论