【问题标题】:EventBus android implementation, why reflectionEventBus android实现,为什么要反射
【发布时间】:2015-07-03 08:43:22
【问题描述】:

我在我的项目中使用 EventBus,它运行良好,但一些大学表示他们在使用这个库时遇到了问题。我不是在谈论 EventBus 模式的 concreate 实现,有两种广泛使用的实现。
但是它们都使用反射。反射并不便宜,尤其是在移动设备上。
所以我的问题是为什么不避免使用反射??
例如,我的想法是使用 Android Service 作为事件总线管理器,或者您可以使用在应用程序生命周期中可用的自定义应用程序类。例如,服务将能够注册订阅者、通知他们、取消注册……EventBus 可以做的所有事情。至于服务是高优先级的组件,我们可以确定它在我们需要发送事件时是活跃的,而且如果我们在应用程序类中会引用它,例如。
关于订阅者,为什么不只实现通用接口OnEventSubscriber<E extends BaseEvent>,如果您对多个事件感兴趣,您可以实现另一个具有适当事件类型的接口。并实现具有特定类型的 onEvent 方法。

为什么当前的实现使用反射方法而不是上面描述的方法?创建这些库的人都是经验丰富的开发人员,因此必须有其实施的原因。
我将不胜感激任何解释,cmets。提前谢谢。

【问题讨论】:

标签: java android reflection event-driven event-bus


【解决方案1】:

请详细说明您指的是哪个 EventBus 实现?

Event Bus 使用的一些真正优势:

  • 快速简单的一对多事件(单个调度器 - 多个接收器)
  • 应用任何部分的全局参考
  • 向不同线程发送/接收事件
  • 速度
  • 粘性事件(在初始竞争条件场景中非常方便),尤其是涉及多个数据层时

实现上述所有功能的强大事件总线是Greenrobot EventBus

你也可以看到这个comparison

LocalBroadcastManager 1) 不能满足以上所有条件 2) 需要更多的编码来调度/监听

【讨论】:

    猜你喜欢
    • 2021-07-25
    • 2018-09-12
    • 2015-11-22
    • 2021-06-09
    • 2010-09-15
    • 2013-08-20
    • 2013-05-01
    • 1970-01-01
    • 2010-12-26
    相关资源
    最近更新 更多