与 ReactiveCocoa 相比,Rx 的一大优势就是更丰富的并发模型。提到并发,就不得不提多线程。在 RxSwift 中,与线程对应的概念就是调度器,本文就调度器做些介绍,包括并发调度器、串行调度器、RxSwift 内置的调度器,及自定义调度器。

文章地址:https://www.cnblogs.com/xjshi/p/9759551.html

调度器抽象出了执行工作的机制,可以不怎么准确的认为调度器对应原本的线程。

observeOnsubscribeOn 这两个操作符可以与调度器配合使用。

如果你想在一个不同的调度器执行工作,那就使用 observeOn(scheduler) 操作符。

如果没有显式指定 observerOn ,那么工作会在产生元素的调度器来执行。

下边是一个使用 observeOn 的例子:

sequence1
.observeOn(backgroundScheduler)
.map { n in
print("This is performed on the background scheduler")
}
.observeOn(MainScheduler.instance)
.map { n in
print("This is performed on the main scheduler")
}

如果想要序列在指定调度器上生成(subscribe 方法)和 dispose,可以使用 subscribeOn(scheduler)

如果没有明确指定 subscribeOn,那么将在调用 subscribe(onNext:)subscribe 的同一调度器上调用 subscribe 闭包(传递给 Observable.create 的闭包)。

如果没有明确指定 subscribeOn,那么将在启动 disposing 的同一调度器上调用 dispose 方法。

简而言之,如果没有显式的选择调度器,那么将在当前调度器上调用这些方法。

串行调度器 vs 并发调度器

由于调度器可以是任何东西,并且所有转换序列的操作副都需要有额外的保证,因此你创建的是哪种调度器非常重要。

这里的保证是指,对所有的序列(Observable)而言,不论它在那个线程上产生元素,如果序列通过 observer.ron(.next(nextElement)) 将一个元素发送给观察者,那么序列在 observer.on 方法执行结束前不能发送下一个元素。

如果 .next 方法没有执行完成,序列也不能发送终止命令,如 .completed.error

这部分内容在RxSwift 入门一文中介绍过。

如果调度器是并发的,Rx 的 observeOnsubscribeOn 操作符将确保一切正常。

如果你使用Rx可以证明是串行的调度器,它能够执行额外的优化。

在串行调度器的情况下, observeOn 被优化为一个简单的 dispatch_async 调用。

自定义调度器

除了当前的调度器,你也可以实现自己的调度器。

如果你想要描述立即执行工作的调度器,可以实现 ImmediateScheduler 协议。

public protocol ImmediateScheduler {
func schedule<StateType>(state: StateType, action: (/*ImmediateScheduler,*/ StateType) -> RxResult<Disposable>) -> RxResult<Disposable>
}

如果你想要支持基于事件的操作,那么你可以实现 Scheduler 协议:

public protocol Scheduler: ImmediateScheduler {
associatedtype TimeInterval
associatedtype Time var now : Time {
get
} func scheduleRelative<StateType>(state: StateType, dueTime: TimeInterval, action: (StateType) -> RxResult<Disposable>) -> RxResult<Disposable>
}

如果你想有周期执行的能力,你可以通过实现 PeriodicScheduler 协议来通知 Rx。

public protocol PeriodicScheduler : Scheduler {
func schedulePeriodic<StateType>(state: StateType, startAfter: TimeInterval, period: TimeInterval, action: (StateType) -> StateType) -> RxResult<Disposable>
}

内置的调度器

上边我们提到 Rx 可以使用所有类型的调度器,但如果 Rx 可以证明调度器是串行的,那么会执行额外的优化

  1. CurrentThreadScheduler:它是一个串行调度器,表示当前执行工作的调度器。
  2. MainScheduler:抽象了需要在主线程执行的工作,当然也是一个串行调度器。
  3. SerialDispatchQueueScheduler:是一个串行调度器,抽象需要在一个 dispatch_queue_t 上执行的工作,它将确保即时传递并发调度队列(concurrent dispatch queue),它也会转换为串行队列。主调度器 也是 SerialDispatchQueueScheduler 的一个示例。
  4. ConcurrentDispatchQueueScheduler:是一个并发调度器,抽象需要在一个 dispatch_queue_t 上执行的工作。当一些任务需要在后台执行时,使用这个调度器。
  5. OperationQueueScheduler:抽象需要在 NSOperationQueue 上执行的工作。适用于需要在后台执行大量工作,并希望通过使用 maxConcurrentOpeartionCount 来调整并发处理的情况。

本文中的部分表示 与 Rx 中的对照:

本文中的表示 Rx中的表示
调度器 scheduler
串行调度器 serial scheduler
并发调度器 concurrent scheduler

RxSwift 中的调度器的更多相关文章

  1. Spring中Quartz调度器的使用

    一.Quartz的特点 * 按作业类的继承方式来分,主要有以下两种: 1.作业类继承org.springframework.scheduling.quartz.QuartzJobBean类的方式 2. ...

  2. 大数据之Yarn——Capacity调度器概念以及配置

    试想一下,你现在所在的公司有一个hadoop的集群.但是A项目组经常做一些定时的BI报表,B项目组则经常使用一些软件做一些临时需求.那么他们肯定会遇到同时提交任务的场景,这个时候到底如何分配资源满足这 ...

  3. [Spring]支持注解的Spring调度器

    概述 如果想在Spring中使用任务调度功能,除了集成调度框架Quartz这种方式,也可以使用Spring自己的调度任务框架. 使用Spring的调度框架,优点是:支持注解(@Scheduler),可 ...

  4. Erlang/OTP 17.0-rc1 新引入的"脏调度器"浅析

    最近在做一些和 NIF 有关的事情,看到 OTP 团队发布的 17 rc1 引入了一个新的特性“脏调度器”,为的是解决 NIF 运行时间过长耗死调度器的问题.本文首先简单介绍脏调度器机制的用法,然后简 ...

  5. Cocos2d-X3.0 刨根问底(六)----- 调度器Scheduler类源码分析

    上一章,我们分析Node类的源码,在Node类里面耦合了一个 Scheduler 类的对象,这章我们就来剖析Cocos2d-x的调度器 Scheduler 类的源码,从源码中去了解它的实现与应用方法. ...

  6. Hadoop的调度器总结

    Hadoop的调度器总结 随着MapReduce的流行,其开源实现Hadoop也变得越来越受推崇.在Hadoop系统中,有一个组件非常重要,那就是调度器,它的作用是将系统中空闲的资源按一定策略分配给作 ...

  7. Erlang调度器细节探析

    Erlang调度器细节探析 Erlang的很多基础特性使得它成为一个软实时的平台.其中包括垃圾回收机制,详细内容可以参见我的上一篇文章Erlang Garbage Collection Details ...

  8. Linux CFS调度器之task_tick_fair处理周期性调度器--Linux进程的管理与调度(二十九)

    1. CFS如何处理周期性调度器 周期性调度器的工作由scheduler_tick函数完成(定义在kernel/sched/core.c, line 2910), 在scheduler_tick中周期 ...

  9. goroutine与调度器

    29 November 2013 by skoo 我们都知道Go语言是原生支持语言级并发的,这个并发的最小逻辑单元就是goroutine.goroutine就是Go语言提供的一种用户态线程,当然这种用 ...

随机推荐

  1. python之“装饰器”

    在python里装饰器 其定义:装饰器就是一个函数,用来装饰其他函数,就是给其他函数添加功能. 装饰器有两个特点: 1.装饰器不修改被装饰函数的源码: 2.装饰器不锈钢被装饰函数的调用方式. 在编程中 ...

  2. RobotFrameWork Web自动化测试环境搭建

    前言 Robot Framework是一款python编写的功能自动化测试框架.具备良好的可扩展性,支持关键字驱动,可以同时测试多种类型的客户端或者接口,可以进行分布式测试执行.主要用于轮次很多的验收 ...

  3. app发布当天,用户无法登录

    原因:当用户登录时候有商城用户的触发器存在,它会让商城用户也更新成登录状态. 由于用户量大,导致数据库锁死. 最后解决案:删掉触发器,在app的接口登录程序里,追加商城用户更新成登录的操作. 他案1: ...

  4. HTML5实时语音通话聊天,MP3压缩传输3KB每秒

    目录 一.把玩方法 二.技术特性 (1)数据传输 (2)音频采集和编码 (3)音频实时接收和播放 三.应用场景 自从Recorder H5 GitHub开源库优化后,对边录边转码成小语音片段文件实时上 ...

  5. jqGrid根据数据动态设置rowList

    superme.rowList = [10,20,50,100]; superme.rowNum = 20; 全局属性 loadComplete : function (data) { if(data ...

  6. POJ 1015 陪审团问题

    题意略. 思路: 这个题目开始我本来打算用个二维dp,令dp[ i ][ j ]为考虑前i个人,有j个名额的时候,我所能获取的最小差,后来发现不好转移.因为dp[ i ][ j ]有可能是+2, 也有 ...

  7. Codeforces 1009G

    题意略. 思路: 首先是贪心, 我们从前往后依次从小到大考虑放哪个字符, 重点是判断放了这个字符后, 对于剩下的后缀是否存在合法解. 考虑每个位置的允许放的字符集合只有2 ^ 6种, 我们预处理一个后 ...

  8. .Net Core 2.2与Java 12性能对比

    我发现基准游戏(https://benchmarksgame-team.pages.debian.net/benchmarksgame/fastest/csharp.html)是一套非常好的基准测试. ...

  9. .NET平台下,钉钉微应用开发之:工作消息通知

    首先看下官方文档,为我们提供了POST请求地址,和几个必传参数的列表以及参数示例,写的都挺详细的. 无奈提供的SDK请求示例是JAVA的,而我用的是.NET的,所以还是摸了一些坑出来,其实也就是不同平 ...

  10. Github资源下载

    自己收集的一些日常使用软件.编程书籍以及自己动手实践的程序,欢迎下载. 收集维护不易,喜欢请Star或Fork支持呀,(^-^)V. 所有资源均自己制作或收集自网络,如有侵权请联系删除. 友情链接 G ...