安卓组件通信:eventBus的使用

来源:互联网 发布:信用评分卡模型python 编辑:程序博客网 时间:2024/05/10 07:12

参考:

http://blog.csdn.net/evan_man/article/details/51328628

一.为什么使用evnetBus

1.EventBus是一个很棒的工具,它可用来对程序组件进行解耦.使代码变得清晰,而且增强了类型安全(type-safe)。
(当用Intent传递数据时,在编译时并不能检查出所设的extra类型与收到时的类型一致。所以一个很常见的错误便是你或者你团队中的其他人改变了Intent所传递的数据,但忘记了对全部的接收器(receiver)进行更新。这种错误在编译时是无法被发现的,只有在运行时才会发现问题。而使用EventBus所传递的消息则是通过你所定义的Event类。由于接收者方法是直接与这些类实例打交道,所以所有的数据均可以进行类型检查,这样任何由于类型不一致所导致的错误都可以在编译时刻被发现。另外就是你的Event类可以定义成任何类型。我通常会为了表示事件而显式地创建明确命名的类,你也通过EventBus发送/接收任何类。通过这种方法,你就不必受限于那些只能添加到Intent extras中的简单数据类型了。例如,你可以发送一个和ORM(注1)模型类实例,并且在接收端直接处理与ORM操作相关的类实例。)
  • 简化了组件之间的通信
  • 对事件的发送者和接收者进行解耦
  • 可以根据业务需求,在Activity,Fragment(UI线程),或者后台线程中执行
  • 避免了复杂且容易出错的依赖关系及生命周期
  • 速度快,专为高性能优化
  • 依赖的jar包体积小(<50K)
  • 对于分发线程的控制,及事件优先级的支持也很好
  • 使用方便,只需要在需要订阅的方法加入@Subscribe 注解即可,由于建立了注释的时间索引,EventBus不需要再运行期执行注解反射
  • 事件订阅者继承,面向对象的规则同样适用于事件和订阅者类,比如,A是B的父类,分发B类型的事件,也会同样分发给关注A事件的订阅者。


  • 二.什么是eventBus
    EventBus是一款针对Android优化的发布/订阅事件总线。主要功能是替代Intent,Handler,BroadCast在Fragment,Activity,Service,线程之间传递消息.优点是开销小,代码更优雅。以及将发送者和接收者解耦。

    、onEvent
    2、onEventMainThread
    3、onEventBackgroundThread
    4、onEventAsync

    这四种订阅函数都是使用onEvent开头的,它们的功能稍有不同,在介绍不同之前先介绍两个概念:
    告知观察者事件发生时通过EventBus.post函数实现,这个过程叫做事件的发布,观察者被告知事件发生叫做事件的接收,是通过下面的订阅函数实现的。

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



    三.如何使用
    1.导入依赖:compile 'de.greenrobot:eventbus:2.4.0'
    compile 'de.greenrobot:eventbus:2.4.0'

    2.定义一个javaBean用于封装数据
    1. public class Message {
    2. private static final String TAG = "Message";
    3. private String msg;
    4. public String getMsg() {
    5. return msg;
    6. }
    7. public void setMsg(String msg) {
    8. this.msg = msg;
    9. }
    10. public Message(String msg) {
    11. this.msg = msg;
    12. }
    13. public Message() {
    14. }
    15. }

    3.在需要接受消息的acitvity或类中注册evnetbus.并且在恰当的时机反注册.
    1. protected void onCreate(Bundle savedInstanceState) {
    2. super.onCreate(savedInstanceState);
    3. setContentView(R.layout.activity_main);
    4. EventBus.getDefault().register(this);
    5. tv = (TextView) findViewById(R.id.textview);
    6. }
    1. protected void onDestroy() {
    2. EventBus.getDefault().unregister(this);
    3. super.onDestroy();
    4. }

    4.重写接受的方法.(该方法有许多种,根据需要重写,该方法的参数是javabean的对象)
    1. public void onEventMainThread(Message msg) {
    2. tv.setText(msg.getMsg());
    3. Toast.makeText(this, msg.getMsg(), Toast.LENGTH_SHORT).show();
    4. }

    5.在需要发布消息的类中得到eventbus对象发布消息
    1. public void sendMessage(View view) {
    2. EventBus.getDefault().post(
    3. new Message("你好吗"));
    4. }

    0 0