当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Swift Optional.Publisher subscribe(on:options:)用法及代码示例


实例方法

subscribe(on:options:)

指定在其上执行订阅、取消和请求操作的调度程序。

声明

func subscribe<S>(
    on scheduler: S,
    options: S.SchedulerOptions? = nil
) -> Publishers.SubscribeOn<Self, S> where S : Scheduler

返回值

在指定调度程序上执行上游操作的发布者。

参数

scheduler

调度程序用于向上游发布者发送消息。

options

自定义元素交付的选项。

详述

与影响下游消息的 Publisher/receive(on:options:) 相比,Publisher/subscribe(on:options:) 更改上游消息的执行上下文。

在以下示例中,Publisher/subscribe(on:options:) 运算符导致 ioPerformingPublisherbackgroundQueue 上接收请求,而 Publisher/receive(on:options:) 导致 uiUpdatingSubscriberRunLoop.main 上接收元素和完成。


let ioPerformingPublisher == // Some publisher.
let uiUpdatingSubscriber == // Some subscriber that updates the UI.


ioPerformingPublisher
    .subscribe(on: backgroundQueue)
    .receive(on: RunLoop.main)
    .subscribe(uiUpdatingSubscriber)

使用 Publisher/subscribe(on:options:) 还会导致上游发布者使用指定的调度程序执行 Cancellable/cancel()

可用版本

iOS 13.0+, iPadOS 13.0+, macOS 10.15+, Mac Catalyst 13.0+, tvOS 13.0+, watchOS 6.0+

相关用法


注:本文由纯净天空筛选整理自apple.com大神的英文原创作品 Optional.Publisher subscribe(on:options:)。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。