RxSwift 系列(二)

前言

Subject是一个代理,它既是Observer,也是Observable。因为它是一个Observer,它可以订阅一个或多个Observable;因为它是一个Observable,它又可以被其他的Observer订阅。它可以传递/转发作为Observer收到的值,也可以主动发射值。

SubjectRxSwift中的实现有四种:

  • PublishSubject
  • ReplaySubject
  • BehaviorSubject
  • Variable

PublishSubject

代理
我们先以PublishSubject为例来解释Subject是一个代理的含义。

let subject = PublishSubject<Int>()
subject.subscribe({ (event) in
    print("Event:\(event)")
})

subject.onNext(1)
subject.onNext(2)
subject.onCompleted()

Subject作为一个Observable提供了subscribe等方法。在订阅之后,我们调用了onNext(),向Observer发射了12,以及onCompleted()。打印结果和我们预期的是一样的。

Event:next(1)
Event:next(2)
Event:completed

我们可以调用Subjecton系列方法主动给Observer发送值。

Subject可以作为代理转发订阅到的结果。例如:

let subject = PublishSubject<Int>()
subject.subscribe({ (event) in
    print("Event:\(event)")
})

let reveseSubject = Observable<Int>.create({ (observer) -> Disposable in
    observer.onNext(1)
    observer.onNext(2)
    observer.onCompleted()

    return Disposables.create()
})

reveseSubject.subscribe(subject)

subject订阅了reveseSubject,并将结果转发给了Observer

注意:Observer订阅 subject时不会收到订阅之前subject的值。

let subject = PublishSubject<Int>()
subject.onNext(0)
subject.subscribe({ (event) in
    print("Event:\(event)")
})

subject.onNext(1)
subject.onNext(2)
subject.onCompleted()

上述代码结果为:

Event:next(1)
Event:next(2)
Event:completed

observer无法接收到0这个值。

ReplaySubject

ReplaySubjectPublishSubject不同的是,Observer有可能接收到订阅之前的值。

let subject = ReplaySubject<Int>.create(bufferSize: 1)

    subject.onNext(0)
    subject.subscribe({ (event) in
        print("Event:\(event)")
    })

    subject.onNext(1)
    subject.onNext(2)
    subject.onCompleted()

上述代码结果为:

Event:next(0)
Event:next(1)
Event:next(2)
Event:completed

ReplaySubject具有重放(replay)的功能,replay的个数可以通过参数指定。我们可以将其理解为缓存的效果。

一般我们使用ReplaySubject的时候,都是先发射,后订阅,然后通过指定缓存的大小,可以获取对应的值。(注意:不考虑Error和Completed)。

let subject = ReplaySubject<Int>.create(bufferSize: 1)

subject.onNext(0)
subject.onNext(1)
subject.onNext(2)
subject.onCompleted()

subject.subscribe({ (event) in
    print("Event:\(event)")
})

上述代码,我们指定了bufferSize等于1,所以只缓存了最新的值,打印结果:

Event:next(2)
Event:completed

当我们需要缓存所有值的时候,可以调用createUnbounded()方法。

ReplaySubject

BehaviorSubject

BehaviorSubject类似于ReplaySubject具有缓存能力,但是略有不同。

  • 只缓存一个最新值,类似ReplaySubject.create(bufferSize: 1)
  • 需要提供默认值
let behaviorSubject = BehaviorSubject<Int>(value: 1)
behaviorSubject.subscribe({ (event) in
    print("Event:\(event)")
})

打印结果为:

Event:next(1)

使用BehaviorSubject有一点好处,我们可以确定当Observer订阅时,至少可以收到最新的一个值。

Variable

VariableBehaviorSubject又很相似,VariableBehaviorSubject的一个封装,同样具备了缓存最新值和提供默认值的能力。但是Variable没有on系列方法,只提供了value属性。
直接对value进行set等同于调用了onNext()方法。

这表明了Variable不会发射error也不会发射completed

Variable被销毁的时候会调用发射completedObserver

在订阅Variable的时候,我们无法直接调用subscribe方法,需要先调用asObservable()方法。

let variable = Variable<Int>(1)
variable.asObservable().subscribe({ (event) in
    print("Event:\(event)")
})
variable.value = 2

上述结果为:

Event:next(1)
Event:next(2)
Event:completed

Variable可以用来储存数据,因为我们可以拥有valuegetset方法。比如:

let variable = Variable(1)
print("Value: \(variable.value)")
variable.value = 2
print("Value: \(variable.value)")

打印结果为:

Value: 1
Value: 2

这是BehaviorSubject不具备的。

时间: 2024-10-05 21:05:07

RxSwift 系列(二)的相关文章

ASP.NET MVC学习系列(二)-WebAPI请求

继续接着上文 ASP.NET MVC学习系列(一)-WebAPI初探 来看看对于一般前台页面发起的get和post请求,我们在Web API中要如何来处理. 这里我使用Jquery 来发起异步请求实现数据调用. 继续使用上一文章中的示例,添加一个index.html页面,添加对jquery的引用. 一.无参数Get请求 一般的get请求我们可以使用jquery提供的$.get() 或者$.ajax({type:"get"}) 来实现: 请求的后台Action方法仍为上篇文章中的GetU

highcharts 结合phantomjs纯后台生成图片系列二之php2

上篇文章中介绍了phantomjs的使用场景,方法. 本篇文章详细介绍使用php,highcharts 结合phantomjs纯后台生成图片.包含一步步详细的php代码 一.highcharts 结合phantomjs纯后台生成图片系列的准备: 下载phantomjs解析插件,从highcharts官方下载所需插件. 新建一个工程文件夹phantomjs,所必备的js文件有: highcharts 结合phantomjs纯后台生成图片系列二之php 其中jquery.js为 v1.7.1; hi

iOS开发UINavigation系列二——UINavigationItem

iOS开发UINavigation系列二--UINavigationItem 一.引言 UINavigationItem是导航栏上用于管理导航项的类,在上一篇博客中,我们知道导航栏是通过push与pop的堆栈操作来对item进行管理的,同样,每一个Item自身也有许多属性可供我们进行自定制.这篇博客,主要讨论UINavigationItem的使用方法. UINavigationBar:http://my.oschina.net/u/2340880/blog/527706. 二.来说说UINavi

windows下mongodb基础玩法系列二CURD操作(创建、更新、读取和删除)

windows下mongodb基础玩法系列 windows下mongodb基础玩法系列一介绍与安装 windows下mongodb基础玩法系列二CURD操作(创建.更新.读取和删除) 简单说几句 在mongodb中3元素:db(数据库).collection(集合).document(文档) 其中collection类似于数据库中的表,document类似于行,这样一来我们就将内容对比起来记忆学习了. 数据格式 MongoDB documents是BSON格式(一种类json的一种二进制形式的存

原始套接字基础(原始套接字系列二)

在进入Raw Socket多种强大的应用之前,我们先讲解怎样建立一个Raw Socket及怎样用建立的Raw Socket发送和接收IP包. 建立Raw Socket 在Windows平台上,为了使用Raw Socket,需先初始化WINSOCK: // 启动 WinsockWSAData wsaData;if (WSAStartup(MAKEWORD(2, 1), &wsaData) != 0){ cerr << "Failed to find Winsock 2.1 or

C# 玩转计算机系列(二)-操作IIS服务

之前由于工作需要自己做一个一键部署的小工具,实现三个模块的功能:TFS操作创建映射并获取最新源代码:SQL Server数据库注册表配置数据库连接:IIS站点部署,生成可访问的IIS站点.由于是基于自己的工作环境下的开发,所以在TFS和SQL Server配置工具化实现,有一些点是默认按照公司的环境配置参数默认的,虽然不是广泛适用每一种情况的环境部署,但是在学习这三个模块的开发过程中,还是有很多东西是可以值得分享的. 今天先分享一下,如何通过工具化实现IIS站点部署和配置,为了可复用性,IIS操

Exchange Server 2013系列二:服务器角色

杜飞 在上一篇文章中,我们提到现在硬件性能的增加以及成本的下降,硬件已经不再成为软件应用的约束因素,特别是CPU,其 计算能力的成本显著降低.Exchange 2013 的主要设计目标是简化缩放.提高硬件利用率和实现故障隔离.Exchange 2013一开始将服务器角色的数目减少到了两个:客户端访问服务器角色和邮箱服务器角色,当然,升级到SP1之后也包含边缘服务器角色或者是边界网络中安装 Exchange 2007 或 Exchange 2010 边缘传输服务器角色.如下图所示: 客户端访问服务

RxSwift 系列(九)

前言 看完本系列前面几篇之后,估计大家也还是有点懵逼,本系列前八篇也都是参考RxSwift官方文档和一些概念做的解读.上几篇文章概念性的东西有点多,一时也是很难全部记住,大家脑子里面知道有这么个概念就行,用的时候,再来查阅一番,慢慢就掌握了. 本篇主要来深入了解一些RxSwift实战中用到的一些重要知识点,这里面有很多自己的理解,所以不免会有一些错误的地方,还请大家多多交流,如有发现错误的地方,欢迎评论. 概念 Rx系列的核心就是Observable Sequence这个相信大家心中已经有所了解

highcharts 结合phantomjs纯后台生成图片系列二之php

上篇文章中介绍了phantomjs的使用场景,方法.本篇文章详细介绍使用php,highcharts 结合phantomjs纯后台生成图片. 一.准备: 下载phantomjs解析插件,从 highcharts官方 下载所需插件. 新建一个工程文件夹名位:phantomjs,所必备的js文件有: 其中jquery.js为v1.7.1; highcharts-convert.js的下载地址可去 github上下载 . highcharts官方文档有关于highcharts-convert.js的使