EventBus的使用详解和封装

EventBus是一款针对Android优化的发布/订阅事件总线。

  • 特点: 主要功能是替代Intent,Handler,BroadCast在Fragment,Activity,Service,线程之间传递消息。
  • 优点: 优点是开销小,代码更优雅。以及将发送者和接收者解耦。

代码块

/**
 * eventBus 注册
 * 子类可实现 该方法
 */
public void registerComponent() {}

/**
 * eventBus 注销
 * 子类可实现 该方法
 */
public void unRegisterComponent() {}
  • 作用: 在子类activity和fragment 中实现该方法,不用关心 注册、注释和其生命周期的关系

流程图:BaseActivity

Created with Raphaël 2.1.0 onCreate registerComponent
Created with Raphaël 2.1.0 onDestroy unRegisterComponent

时序图:子类activity

Created with Raphaël 2.1.0 A A B B post(event) 互相发送消息 post(event)

代码块:发送事件

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);
}

具体建议请参考以下链接
链接

EventBus是一个开源的发布/订阅事件总线库,它简化了不同组件之间的通信,避免了紧密耦合的代码。它使用了观察者模式,让不同的组件能够在没有直接关联的情况下相互通信。下面是EventBusAndroid中的使用详解。 1.导入EventBus库 在build.gradle文件中添加以下代码: ``` dependencies { implementation 'org.greenrobot:eventbus:3.2.0' } ``` 2.定义事件类 定义一个事件类,用于传递数据。 ```java public class MessageEvent { public final String message; public MessageEvent(String message) { this.message = message; } } ``` 3.注册EventBus 在需要接收事件的组件中注册EventBus。 ```java @Override public void onStart() { super.onStart(); EventBus.getDefault().register(this); } ``` 4.注销EventBus 在不需要接收事件的组件中注销EventBus。 ```java @Override public void onStop() { super.onStop(); EventBus.getDefault().unregister(this); } ``` 5.发布事件 在发送事件的组件中发布事件。 ```java EventBus.getDefault().post(new MessageEvent("Hello EventBus!")); ``` 6.订阅事件 在接收事件的组件中订阅事件。 ```java @Subscribe(threadMode = ThreadMode.MAIN) public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } ``` 7.指定线程模式 EventBus支持在不同的线程中处理事件,可以通过@Subscribe注解的threadMode参数指定线程模式。 ```java @Subscribe(threadMode = ThreadMode.MAIN) // 主线程 public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } @Subscribe(threadMode = ThreadMode.BACKGROUND) // 后台线程 public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } @Subscribe(threadMode = ThreadMode.ASYNC) // 异步线程 public void onMessageEvent(MessageEvent event) { String message = event.message; // 处理事件 } ``` EventBus使用非常简单,但是需要注意以下几点: - 订阅方法必须使用@Subscribe注解,并且方法必须是public、void类型。 - 发布事件和接收事件的参数类型必须一致。 - 在注册EventBus时,不要忘记在onStop()方法中注销EventBus,否则可能会引起内存泄漏。 - EventBus默认在主线程中处理事件,如果事件处理需要耗时操作,可以使用不同的线程模式。 - EventBus不支持跨进程通信,只能在同一进程中的组件之间进行通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

寻找DX3906

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值