• EventBus 一篇文章就够了


    早年我写过一篇关于EventBus的文章,基本上把原理也讲的差不多了,今天再次捡起来做一个总结。附上链接:

    EventBus源码详解_AD钙奶-lalala的博客-CSDN博客

    我们知道Android开发早期各种Activity之间,Fragment之间,Activity和Fragment之间传递数据显得不是那么的友好。EventBus的出现大大提高了组件之间的数据传递效率,大大降低了接口回调传递数据所带来的代码耦合。EventBus很小巧,运行效率高,因此早期被大量运用在各种项目中。

    我们来补充一下EventBus的使用,首先引入库:

    implementation 'org.greenrobot:eventbus:3.0.0'

    使用步骤:

    1. 1、定义一个数据model,比如一个bean类,作为传递的数据类型
    2. 2、在需要观察接收数据的类中注册:EventBus.getdefault().register(this);
    3. 3、注册的类里面 添加接收方法,以在主线程接收为例:
    4. @Subscribe(threadMode = ThreadMode.MAIN)
    5. public void onEvent(Model model) {
    6. // TODO someThing
    7. }
    8. 4、发送消息,在想发送的逻辑处加一行EventBus.getdefault().post(model);
    9. 5、在不用的时候,反注册,比如在activity的onDestroy中unregister。

    原理总结:

    在这里插入图片描述

    •  注册的时候,通过反射拿到这个类,再通过反射拿到这个类的所有方法;
    • 筛选出方法的修饰符为PUBLIC和参数个数为1的方法;
    • 判断方法是否有Subscribe注解;
    • 满足条件的加到一个List里面;
    • 遍历List集合调用subscribe方法;
    • subscribe方法的核心是subscriptionsByEventType在这个Map里面,以传递Model类型为键,以Subscription(subscriber, subscriberMethod)为值;
    • post发送调用postSingleEvent;
    • 再调用postSingleEventForEventType;
    • subscriptions = subscriptionsByEventType.get(eventClass),从Map里面拿;
    • 遍历subscriptions;
    • subscription.subscriberMethod.method.invoke(subscription.subscriber, event),反射调用。

  • 相关阅读:
    java 不同方式的加锁
    cookie and session
    11.23二叉树
    MySQL基础篇总结
    Elasticsearch模拟网络丢包
    租用服务器可以干什么呢?
    【Kubernetes】浅聊Kubernetes中的容器和镜像
    Java版本的工程项目管理系统源代码之工程项目管理系统面临的挑战
    【JMeter】JMeter压测过程中遇到Non HTTP response code错误解决方案
    python——GIL锁详解
  • 原文地址:https://blog.csdn.net/qq_36428821/article/details/126940460