Front-end
Apple
Apple
  • 第三方库
    • RAC库
      • ReactiveObjc
        • 如何实现的
        • 有关类
        • 有关协议
        • 关键概念列表
          • RACSignal有关类
            • RACStream
              • 头文件定义
            • RACSignal
              • 头文件定义内容
              • 核心代码
              • 常用的方法
                • concat:
                • bind:
                • zipWith 和merge
            • RACSubject
              • 内容
            • RACReplaySubject
              • 内容
            • RACBehaviorSubject
              • 内容
            • RACGroupedSignal
              • 内容
            • RACDynamicSignal
              • RACDynamicSignal
              • RACSignal vs RACDynamicSignal
            • RACReturnSignal
              • 内容
            • RACErrorSignal
            • RACEmptySignal
            • RACChannelTerminal
            • 疑问
              • RACChannelTerminal vs RACSubject
              • RACSignal vs RACStream
              • 热信号和冷信号
                • 进一步理解
              • 信号的发送者和接受者
                • RACSignal 不是信号对象么?为什么信号的发送者是自己呢?
          • RACChannel有关类
            • RACChannel
              • Page 1
              • 用于MVVM架构
              • RAC() vs RACChannelTo()
            • RACKVOChannel
              • 内容
              • 封装了系统的KVO
          • RACCommand
          • RACSubscriber
          • RACTuple
          • RACSequence有关类
          • RACKVOTrampoline
            • NSObject+RACKVOWrapper.h
            • NSObject+RACKVOWrapper.m
          • Page
          • 宏
          • 疑问
            • RACCommand vs RACSignal
            • 有了信号量,为什么还需要RACCommand
        • 操作方法
          • reduce
            • reduce 在不同语言以及库中是否一样的概念?
      • ReactiveSwift
        • 相比ReactiveObjc
      • RxSwift
      • Combine
      • 疑问
        • 热信号 vs 冷信号
        • ReactiveObjC 和 ReactiveSwift 实现原理差异
        • ReactiveObjC、ReactiveCocoa、ReactiveSwift的关系与区别
        • ReactiveObjC、ReactiveCocoa、ReactiveSwift内容
        • ReactiveSwift vs RxSwift
        • RxSwift、ReactiveSwift 和 ReactiveObjC
        • RxSwift、ReactiveSwift 、Combine
    • swift源码
      • 编译
        • 命令参数解释
        • 涉及到的工具
          • cmake 和 ninja
          • sccache
        • Rosetta模式
        • 遇到问题
          • FETCH_HEAD': Permission denied
          • --local_compiler_build': No such file or directory
          • ld: unsupported tapi file type '!tapi-tbd' in YAML file
          • python --version 显示没有这个命令
          • ModuleNotFoundError: No module named 'packaging'
          • ModuleNotFoundError: No module named 'sphinx'
            • sphinx是什么
          • ERROR: Could not find a version that satisfies the requirement sphinx (from versions: none)
          • /Applications/Python\ 3.x/Install\ Certificates.command 失败
          • 已经安装了sphinx,还是显示错误
      • 涉及到的知识点
        • Swift中的MCCAS
Powered by GitBook
On this page
  1. 第三方库
  2. RAC库
  3. ReactiveObjc
  4. 关键概念列表
  5. RACSignal有关类
  6. RACReplaySubject

内容

RACReplaySubject 是 ReactiveCocoa 中的一种 特殊的热信号,它与 RACSubject 相似,但具有 事件缓存功能。它允许将历史事件缓存下来,新订阅者可以接收到之前的事件,尤其适合在需要保留和重放事件的场景中使用。

RACReplaySubject 的特点

  1. 事件缓存:RACReplaySubject 会将发送的事件存储起来,新订阅者可以收到已缓存的历史事件。可以通过设置缓存数量来控制保留多少个事件。

  2. 热信号:RACReplaySubject 在被创建和触发后就立即发送事件,不需要等待订阅者。

  3. 多播特性:RACReplaySubject 支持多个订阅者,所有订阅者会收到相同的事件。

RACReplaySubject 的常用方法

与 RACSubject 类似,RACReplaySubject 也有如下方法用于发送事件:

  • sendNext::发送一个 next 事件。

  • sendError::发送一个错误事件,并结束信号。

  • sendCompleted:发送完成事件,通知所有订阅者信号结束。

创建和使用示例

1. 基本使用

创建一个 RACReplaySubject,发送事件并进行订阅:

// 创建一个 RACReplaySubject
RACReplaySubject *replaySubject = [RACReplaySubject subject];

// 发送事件
[replaySubject sendNext:@"Event 1"];
[replaySubject sendNext:@"Event 2"];

// 订阅者 1
[replaySubject subscribeNext:^(id  _Nullable x) {
    NSLog(@"Subscriber 1 received: %@", x);
}];

输出:

Subscriber 1 received: Event 1
Subscriber 1 received: Event 2

在这个例子中,replaySubject 在订阅之前就发送了 "Event 1" 和 "Event 2"。当订阅者 1 订阅时,立即收到了这些历史事件。

2. 多个订阅者的情况下重放事件

每个新订阅者都会接收到所有已缓存的事件:

// 创建一个 RACReplaySubject
RACReplaySubject *replaySubject = [RACReplaySubject subject];

// 发送事件
[replaySubject sendNext:@"Event 1"];
[replaySubject sendNext:@"Event 2"];

// 第一个订阅者
[replaySubject subscribeNext:^(id x) {
    NSLog(@"Subscriber 1 received: %@", x);
}];

// 发送新的事件
[replaySubject sendNext:@"Event 3"];

// 第二个订阅者
[replaySubject subscribeNext:^(id x) {
    NSLog(@"Subscriber 2 received: %@", x);
}];

输出:

Subscriber 1 received: Event 1
Subscriber 1 received: Event 2
Subscriber 1 received: Event 3
Subscriber 2 received: Event 1
Subscriber 2 received: Event 2
Subscriber 2 received: Event 3

在这个例子中,第一个订阅者接收到所有事件,包括 "Event 3"。第二个订阅者也接收到所有已缓存的事件,尽管在 "Event 3" 之后才订阅。

3. 设置缓存大小

可以指定 RACReplaySubject 缓存的事件数量:

// 创建一个只缓存最后一个事件的 RACReplaySubject
RACReplaySubject *replaySubject = [RACReplaySubject replaySubjectWithCapacity:1];

// 发送多个事件
[replaySubject sendNext:@"Event 1"];
[replaySubject sendNext:@"Event 2"];

// 订阅信号
[replaySubject subscribeNext:^(id x) {
    NSLog(@"Received: %@", x);
}];

输出:

Received: Event 2

因为缓存大小设置为 1,replaySubject 仅缓存最新的 "Event 2",所以新订阅者只接收到 "Event 2"。

RACReplaySubject 和 RACSubject 的区别

  • 缓存机制:RACReplaySubject 会缓存历史事件,并在新的订阅者加入时重放这些事件;RACSubject 不缓存事件,只有当前订阅者可以接收到事件。

  • 适用场景:RACReplaySubject 适合需要保存事件状态并让新订阅者接收到历史事件的场景;而 RACSubject 更适合实时事件广播。

适用场景

  • 状态重放:例如,网络请求成功后缓存数据并允许新加入的订阅者接收数据。

  • 事件广播:RACReplaySubject 适合用于在多处广播同样的事件或状态。

  • 避免事件丢失:使用缓存功能确保新订阅者能接收到之前的重要事件,不会因为订阅顺序不同而丢失数据。

总结

RACReplaySubject 是 ReactiveCocoa 中重要的信号类型之一,它通过缓存事件并重放给新订阅者,能解决一些常见的状态保留问题。在需要保证事件不丢失或新订阅者能接收到过去事件的场景中,它是一个非常有用的工具。

PreviousRACReplaySubjectNextRACBehaviorSubject

Last updated 8 months ago