zoukankan      html  css  js  c++  java
  • Android 通信 EventBus

    参考:

    EventBus是一个publish/subscribe (发布 / 订阅) 消息的总线,简化了应用程序内各组件间、组件与后台线程间的通信。比如请求网络,等网络返回时通过Handler或Broadcast通知UI,两个Fragment之间需要通过Listener通信,这些需求都可以通过EventBus实现。

    GitHub地址:https://github.com/greenrobot/EventBus

    作为一个消息总线,有三个主要的元素:

    • Event:事件
    • Subscriber:事件订阅者,接收特定的事件
    • Publisher:事件发布者,用于通知Subscriber有事件发生

    e.g. 使用方式:

    1.  在订阅事件的activity中创建 onEvent方法。

    2.  EventBus.getDefault().register(this);//订阅事件。

      register会把当前类中匹配的方法(是否以onEvent开头,是否是public且非static和abstract方法,是否是一个参数),存入一个map(EventBus存储方法的地方)。

    3.  EventBus.getDefault().post(object);//在任何业务逻辑处理中发布事件。

      根据实参去map查找进行反射调用。

    4.  EventBus.getDefault().unregister(this);//在activity ondestroy中取消订阅。

    其中 onEvent方法 对应 post那边的 ThreadMode:

    • PostThread:(对应onEvent)事件的处理在和事件的发送在相同的进程,所以事件处理时间不应太长,不然影响事件的发送线程,而这个线程可能是UI线程。
    • MainThread: (对应onEventMainThread)事件的处理会在UI线程中执行。事件处理时间不能太长,这个不用说的,长了会ANR的。
    • BackgroundThread:(对应onEventBackgroundThread)事件的处理会在一个后台线程中执行,虽然名字是BackgroundThread,事件处理是在后台线程,但事件处理时间还是不应该太长,因为如果发送事件的线程是后台线程,会直接执行事件,如果当前线程是UI线程,事件会被加到一个队列中,由一个线程依次处理这些事件,如果某个事件处理时间太长,会阻塞后面的事件的派发或处理。
    • Async对应onEventBackgroundThread)事件处理会在单独的线程中执行,主要用于在后台线程中执行耗时操作,将任务加入到后台的一个队列,最终由Eventbus中的一个线程池去调用;线程池与BackgroundThread用的是同一个。

    其中BackgroundThread和Async的区别是:

    BackgroundThread中的任务,一个接着一个去调用,中间使用了一个布尔型变量handlerActive进行的控制。

    Async则会动态控制并发。

  • 相关阅读:
    ThinkPHP 3.1.2 查询方式的一般使用1
    ThinkPHP 3.1.2 查询方式的一般使用1
    php 前台数据显示
    php 前台数据显示
    CURD 例子
    CURD 例子
    ThinkPHP 3 的CURD介绍
    华为云服务器实战 之 Gitlab安装与配置使用
    【Python3网络爬虫开发实战】1.3.4-tesserocr的安装
    【Python3网络爬虫开发实战】1.3.3-pyquery的安装
  • 原文地址:https://www.cnblogs.com/CharlesGrant/p/4979829.html
Copyright © 2011-2022 走看看