EventBus是一款针对Android优化的发布/订阅事件总线。
- 特点: 主要功能是替代Intent,Handler,BroadCast在Fragment,Activity,Service,线程之间传递消息。
- 优点: 优点是开销小,代码更优雅。以及将发送者和接收者解耦。
代码块
/**
* eventBus 注册
* 子类可实现 该方法
*/
public void registerComponent() {}
/**
* eventBus 注销
* 子类可实现 该方法
*/
public void unRegisterComponent() {}
- 作用: 在子类activity和fragment 中实现该方法,不用关心 注册、注释和其生命周期的关系
流程图:BaseActivity
时序图:子类activity
代码块:发送事件
CustomerBusEvent customerBusEvent = new CustomerBusEvent(CustomerBusEvent.ACTION_CUSTOMER_NAME_STRING);
customerBusEvent.setCustomerName("设置客户名称消息");
BusProvider.getInstance().postSticky(customerBusEvent);
**注意:**postSticky(event)是发送粘性事件,大部分情况下使用post(event)
代码块:接收事件
/**
* 不管从哪个线程发出的事件,MAIN模式都会在UI(主线程)线程执行onMessageEventMain()方法, 在这里可以更新UI的操作,不可以执行耗时的操作
* @param backBusEvent
*/
@Subscribe(threadMode = ThreadMode.MAIN, priority = 1)
public void updateButton(BackBusEvent backBusEvent){
}
/**
* 不管从哪个线程发出的事件,ASYNC模式都会创建一个新的子线程来执行onEventAsync()方法,所以在这里不能执行更新UI的操作,可以执行耗时的操作
* @param backBusEvent
*/
@Subscribe(threadMode = ThreadMode.ASYNC, priority = 4)
public void updateUI(BackBusEvent backBusEvent){
}
/**
* 事件从哪个线程发布出来的,onMessageEventPost()方法就会在该线程中运行, 如果发送事件的线程是UI线程,则在UI线程执行, 如果发送事件的线程是子线程,则在该子线程中执行
* @param backBusEvent
*/
@Subscribe(threadMode = ThreadMode.POSTING, priority = 2,sticky = true)
public void updateMethod(BackBusEvent backBusEvent){
}
- 讲解:从上面的代码,我们可以看到,EventBus是怎么接收消息的,是根据参数中类的实例的类型的判定的,所以当如果我们在接收时,同一个类的实例参数有两个函数来接收会怎样?答案是,这两个函数都会执行。
我定义了 3个event
priority事件优先级
//priority越大,级别越高
@Subscribe(priority = 1);
public void onEvent(MessageEvent event) {
…
}
混淆
“` java
-keepattributes Annotation
-keepclassmembers class ** {
@org.greenrobot.eventbus.Subscribe ;
}
-keep enum org.greenrobot.eventbus.ThreadMode { *; }
Only required if you use AsyncExecutor
-keepclassmembers class * extends org.greenrobot.eventbus.util.ThrowableFailureEvent {
(java.lang.Throwable);
}
具体建议请参考以下链接
链接