EventBus是一个很棒的工具,它可用来对程序组件进行解耦。在接下来的几篇文章中我将会阐述如何通过它来简化代码,提高可读性以及简化测试。但在本文中我想首先讨论一下为什么我会选择使用EventBus。特别是我会将其与同类技术进行对比。
对比Java监听器接口(Listener Interfaces)
在Java中,特别是Android,一个常用的模式就是使用”监听器(Listeners)”接口。在此模式中,一个实现了监听器接口的类必须将自身注册到它想要监听的类中去。这就意味着监听与被监听之间属于强关联关系。这种关系就使得单元测试很难进行开展。Jake Wharton在他的《使用Otto解耦Android应用间通信》这篇文章中很好地阐述了这个问题,在此我就不进行展开了。
对比本地广播管理器(LocalBroadcastManager)
另一项技术就是在组件间通过本地广播管理器(LocalBroadcastManager)进行消息的发送与监听。虽然这对于解耦有很好的帮助,但它的API不如EventBus那样简洁。此外,如果你不注意保持Intent extras类型的一致,它还可能引发潜在的运行时/类型检测错误。
第一步:首先我们需要导入EventBus的依赖
第二步:我们需要知道EventBus是谁需要接受数据谁来注册它,在这里还有一个小小的注意点,如果不是粘性事件就不能再点击事件中注册,否则他也出不来。
注册我们用到
EventBus.getDefault().register(this);发送消息:
EventBus.getDefault().postSticky(new EventBusStickyMessage("都是几把"));这里
EventBusStickyMessage是一个接收消息的容器,public class EventBusStickyMessage { public String message; public EventBusStickyMessage(String message) { this.message = message; } }