EventBus - 1 核心概念:事件传递/EventBus的优点/传统handler通信的两种方式(更新中)
传统的Android组件之间的通信方式有:Handler, 广播, 接口回掉,相对于EventBus来说,代码过于复杂。。
使用EventBus的建议:
- 并不建议将应用中所有的事件都通过EventBus进行发送,尤其对于一对一的组件之间通信,建议不要使用EventBus。EventBus的使用场景更像是一种广播,当我们向EventBus发送一个事件,则该事件将会传递给多个该事件的订阅者,比如Service向Activities发送事件。跟LoacalBroadCast有点近似
- 在Activity和Fragment中使用EventBus时,要注意在组件的生命周期开始时registered EventBus,在生命周期结束时unregistered EventBus。否则容易导致OOM;
使用EventBus的好处在于:
- 简化组件之间的通信方式
- 让业务代码更加简洁(但是需要配合相应注解进行使用)
- 可以指定事件处理方法的执行线程,和订阅者的优先级(跟广播类似)
- 足够的稳定,已经被很多Android应用使用,你绝对不是第一个吃螃蟹的人
- EventBus实现了解耦,事件的创建和分发由EventBus管理,工作在一个单独的线程。EventBus的工作原理如下图:
传统handler通信的两种方式: 视05:10,