比较RAC和RxSwift

序言

首先先介绍两个概念, Reactive ExtensionsFunctional Reactive Programming(FRP)。

Reactive Extensions

Reactive Extensions原来是由微软提出的一个综合了异步和基于事件驱动编程的库包,使用可观察序列和LINQ-style查询操作。

事件驱动编程

事件,事件代表过去发生的事件,事件既是技术架构方面的概念,也是业务概念。以事件为驱动的编程模型称为事件驱动架构EDA
EDA是一种以事件为媒介,实现组件或服务之间最大松耦合的方式。传统面向接口编程是以接口为媒介,实现调用接口者和实现接口者之间的解耦,就是我们平常开发中的请求网络数据,解析数据,但是这种解耦程度不是很高,如果接口发生变化,双方的代码都需要变动,而事件驱动则是调用者和被调用者互相不知道对方,两者只和中间消息队列耦合。就像古人结婚一样,男女双方不见面,需要了解什么对方的情况只能通过媒人来了解,当然这个例子举的不太合适。下面用个图直接明了的表明一下这种方式。

EDA

事件驱动有以下特征:

1.生产者producer发生实时事件
2.推送通知
3.生产者发送消息面
4.消费者consumer立即响应
5.事件和命令是有区别的

事件驱动还有异步特征,传统方法就像我们iOS中调用什么什么method(),是一种同步模型,必须等待调用者执行完这段代码后才可以执行其他代码。而对于异步模型来说,事件生产者发出事件后,不必等待回应,可以继续执行下面的代码。

当然,还有一个重要的概念就是不代表使用了消息系统架构的都叫做EDA,还有面向服务驱动架构的SOA里面也使用了消息系统作为ESB,服务端的东西我不了解,我们做前端的也不需要过多的了解。

Functional Reactive Programming(FRP)

Functional Reactive Programming(FRP)叫做函数式反应式编程,是一种和事件流有关的编程方式,关注导致状态值改变的行为事件,一系列事件组成了事件流。
FRP是更加有效率的处理事件流,而无需显式去管理状态。
具体来说,FRP包括两个核心观点:
1.事件流,离散事件序列
2.属性,代表模型连续的值
一系列事件是导致值发生变化的原因。

总述

Rx是Reactive Extensions 的一部分,其他的开发语言比如C#,Java,JS等也有Rx。
RAC是 受 Functional Reactive Programming(FRP) 启发,但是在最近一段时间里,他们提到也受到Reactive Extensions 的启发。最终结果就是一个从Rx借鉴了一些东西,但是有着源自FRP名声的一个框架。
无论是Rx还是RAC,都不是真正意义上的FRP。
RAC是一个有着三年历史的项目了,从最初的OC开始,到3.0开始支持swift,现在直接停止了对OC的维护和更新。
Rx是严格按照ReactiveX这个组织的规定开发的,所以如果真正学会了RxSwift,再去学习什么Rx.net,Rx.js,Rx.java,都是洒洒水了,只是语法上的差异而已。

分析

RAC3.0主要有两个实体,signalSignalProducer
signal无论是否绑定了订阅者都可以发布事件。
SignalProducer要有一个信号或者事件产生才会触发。
这两个区别是为了区分冷信号和热信号。what?你说你不知道什么是热信号,什么是冷信号。好吧

热信号是主动的,即使你没有订阅事件,它仍然会时刻推送。而冷信号是被动的,只有当你订阅的时候,它才会发送消息。
热信号可以有多个订阅者,是一对多,信号可以与订阅者共享信息。而冷信号只能一对一,当有不同的订阅者,消息会从新完整发送。

在RxSwift中,signalSignalProducer变成了Observable,这两个实体在Rx中是一个东西。在RxSwift里创建Observables不需要考虑是冷信号还是热信号。冷/热信号是当你subscribing/observing产生的副作用。

对于订阅的概念两者基本是一样的。在RAC里有一点小的区别,RAC可以中断一个事件,当信号被disposed,即使在事件发送完成信号之前。
下面说一下两者订阅时共有的吧
Next
处理新收到的值
Error
处理一个错误,结束整个流,对所有的观察者取消订阅
Complete
标记整个流已经完成,取消所有观察者的订阅
另外RAC会在收到一个disposed Signal 后中断,即使没有收到complete或者error。

在RAC中,Signal/SignalProducer都只是只读的实体,他们不能从外部被改变,RxSwift中的Observable也是如此。如果要把Signal/SignalProducer改变成可以手动改写的实体的话,你只能通过调用管道pipe()函数返回一个可以改动的对象。在Rx中,这是一个不同的类型叫做Subject

RAC是连续的,串行,而Rx可以支持并发。

在Rx中所有的observable的实体的类型都是ObservableType,所以我们可以轻松的用同一个操作符将Subject和Observable的实例组合起来。
在RAC中,Signal和SignalProducer是两种不同的对象。我们必须把SignalProducer转换成Signal后才能compose由Signal实例产生的信号。这两个对象拥有各自的操作符。所以当你需要混合使用它们时,你必须考虑到某种操作符是否是两者通用,这个时候你也不必关心冷/热的处理了。
现在signal的API主要关注在处理next上,让你可以改变值,skipdelaycombineLatest并且在不同的线程里观察值。signal producer的API主要处理信号的生命周期事件(completed,error),和一些这样的操作:thenflatMaptakeUntilcatch
skip
跳过几个信号,不接受
delay
延迟发送next
combineLatest
将多个信号合并起来,并且拿到各个信号的最新的值,必须每个合并的signal至少都有过一次sendNext,才会触发合并的信号。
then
用于连接两个信号,当第一个信号完成,才会连接then返回的信号
flatMap
用于把源信号内容映射成一个新的内容
takeUntil
获取信号直到某个信号执行完成
catch
用于封装一个错误处理机制的signal,也就是当signal1出现了错误,将创建一个新的错误处理signal2,完成后并处理订阅者的流程,举个例子,如果要为服务器上的某个商品点赞+1,但是出现了网络不通,这个时候就要把UserDefault里的值减1

在RAC中还有ActionProperty的概念。Action是一种处理副作用的类型,主要和用户交互相关。Property用于观察当执行一个任务后值改变了的情况。
在Rx中Action也会转变成一个Observable类型。RAC中的Property对应于Rx中的Variable或者BehaviourSubject

结论

通过本文大家可以自己抉择是用Rx呢还是RAC,个人意见是如果你的项目是主OC,不妨使用RAC,因为RAC在cocoa领域是很成熟的,如果项目是主Swift,不如尝试下Rx,一劳永逸。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,056评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,842评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,938评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,296评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,292评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,413评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,824评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,493评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,686评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,502评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,553评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,281评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,820评论 3 305
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,873评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,109评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,699评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,257评论 2 341

推荐阅读更多精彩内容