本文是 “RxJava 沉思录” 系列的最后一篇分享。本系列所有分享:
我们在本系列开篇中,曾经留了一个问题:RxJava 是否可以让我们的代码更简洁?作为本系列的最后一篇分享,我们将详细地探讨这个问题。承接前面两篇 “时间维度” 和 “空间维度” 的探讨,我们首先从 RxJava 的维度 开始说起。
RxJava 的维度
在前面两篇分享中,我们解读了很多案例,最终得出结论:RxJava 通过 Observable
这个统一的接口,对其相关的事件,在空间维度和事件维度进行重新组织,来简化我们日常的事件驱动编程。
前文中提到:
有了
Observable
以后的 RxJava 才刚刚插上了想象力的翅膀。
RxJava 所有想象力的基石和源泉在于 Observable
这个统一的接口,有了它,配合我们各种各样的操作符,才可以在时间空间维度玩出花样。
我们回想一下原先我们基于 Callback 的编程范式:
btn.setOnClickListener(v -> {
// handle click event
})
在基于 Callback
的编程范式中,我们的 Callback
是 没有维度 的。它只能够 响应孤立的事件,即来一个事件,我处理一个事件。假设同一个事件前后存在依赖关系,或者不同事件之间存在依赖关系,无论是时间维度还是空间维度,如果我们还是继续用 Callback
的方式处理,我们必然需要新增许多额外的数据结构来保存中间的上下文信息,同时 Callback
本身的逻辑也需要修改,观察者的逻辑会变得不那么纯粹。
但是 RxJava 给我们的事件驱动型编程带来了新的思路,RxJava 的 Observable
一下子把我们的维度拓展到了时间和空间两个维度。如果事件与事件间存在依赖关系,原先我们需要新增的数据结构以及在 Callback 内写的额外的控制逻辑的代码,现在都可以不用写,我们只需要利用 Observable
的操作符对事件在时间和空间维度进行重新组织,就可以实现一样的效果,而观察者的逻辑几乎不需要修改。
所以如果把 RxJava 的编程思想和传统的面向 Callback 的编程思想进行对比,用一个词形容的话,那就是 降维打击。
这是我认为目前大多数与 RxJava 有关的技术分享没有提到的一个非常重要的点,并且我认为这才是 RxJava 最精髓最核心的思想。RxJava 对我们日常编程最重要的贡献,就是提升了我们原先对于事件驱动型编程的思考的维度,给人一种大梦初醒的感觉,和这点比起来,所谓的 “链式写法” 这种语法糖什么的,根本不值一提。
生产者消费者模式中 RxJava 扮演的角色
无论是同步还是异步,我们日常的事件驱动型编程可以被看成是一种 “生产者——消费者” 模型:
在异步的情况下,我们的代码可以被分为两大块,一块生产事件,一块消费事件,两者通过 Callback 联系起来。而 Callback 是轻量级的,大多数和 Callback 相关的逻辑就仅仅是设置回调和取消设置的回调而已。
如果我们的项目中引入了 RxJava ,我们可以发现,