Android EventBus 简单使用

1.  集成:

GitHub 地址  EventBus

1.1:

implementation 'org.greenrobot:eventbus:3.0.0'

1.2 注册EventBus (在需要回调的页面注册)

EventBus.getDefault().register(this);

别忘记在 onDestory 中解绑

EventBus.getDefault().unregister(this);

回调有一下几种,其对应的功能:

onEvent:如果使用onEvent作为订阅函数,那么该事件在哪个线程发布出来的,onEvent就会在这个线程中运行,也就是说发布事件和接收事件线程在同一个线程。使用这个方法时,在onEvent方法中不能执行耗时操作,如果执行耗时操作容易导致事件分发延迟。
onEventMainThread:如果使用onEventMainThread作为订阅函数,那么不论事件是在哪个线程中发布出来的,onEventMainThread都会在UI线程中执行,接收事件就会在UI线程中运行,这个在Android中是非常有用的,因为在Android中只能在UI线程中跟新UI,所以在onEvnetMainThread方法中是不能执行耗时操作的。
onEventBackground:如果使用onEventBackgrond作为订阅函数,那么如果事件是在UI线程中发布出来的,那么onEventBackground就会在子线程中运行,如果事件本来就是子线程中发布出来的,那么onEventBackground函数直接在该子线程中执行。
onEventAsync使用这个函数作为订阅函数,那么无论事件在哪个线程发布,都会创建新的子线程在执行onEventAsync.

1.3 发送消息:

EventBus.getDefault().post("sssssss");

2. 报错:

Caused by: org.greenrobot.eventbus.EventBusException: Subscriber class com.duke.mvvmtesr.MainActivity and its super classes have no public methods with the @Subscribe annotation

需要在接收方法上加 

 

@Subscribe(threadMode = ThreadMode.MAIN)

在3.0以后回调方法可以自定义, 但需要加上线程模型

  • POSTING:默认,表示事件处理函数的线程跟发布事件的线程在同一个线程。
  • MAIN:表示事件处理函数的线程在主线程(UI)线程,因此在这里不能进行耗时操作。
  • BACKGROUND:表示事件处理函数的线程在后台线程,因此不能进行UI操作。如果发布事件的线程是主线程(UI线程),那么事件处理函数将会开启一个后台线程,如果果发布事件的线程是在后台线程,那么事件处理函数就使用该线程。
  • ASYNC:表示无论事件发布的线程是哪一个,事件处理函数始终会新建一个子线程运行,同样不能进行UI操作。

 

3.疑问:

如果有多个页面注册了EventBus 并且也有接收方法,系统如何区分消息发给了谁?

解答:

在post 的 时候,后面有个参数,在接收方法后面也有个参数,

EventBus.getDefault().post("sssssss");
public void onEventMainThread(String event)

如需要区分具体给哪个接收器发消息,就得通过实体类,去区分不同的类型。

 

至此就可以简单的玩玩 EventBus了,然后如需学习 EventBus 的具体原理等,请参照其他文章。

 

 

你可能感兴趣的:(Android EventBus 简单使用)