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. RACBehaviorSubject

内容

RACBehaviorSubject 是 ReactiveCocoa 中的一种特殊类型的信号,具有 只缓存最新事件 的特点。它适合用于始终保持并提供最新状态的场景中,新订阅者会立即收到最后一个事件(如果有),并且可以继续接收后续的事件。

RACBehaviorSubject 的特点

  1. 只缓存最新事件:RACBehaviorSubject 只会缓存并保留最新的事件,新订阅者订阅时可以立即收到该事件。

  2. 保证初始值:创建时可以指定一个默认值,这个值会作为第一个事件发送给订阅者,直到发送了新的事件。

  3. 热信号:事件会被直接发送给当前的订阅者,而不是等待订阅者订阅后才执行。

  4. 多播特性:支持多个订阅者接收同一事件。

创建和使用示例

1. 基本使用

创建一个 RACBehaviorSubject,设置初始值并进行订阅:

// 创建一个带初始值的 RACBehaviorSubject
RACBehaviorSubject *behaviorSubject = [RACBehaviorSubject behaviorSubjectWithDefaultValue:@"Initial Value"];

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

// 发送新事件
[behaviorSubject sendNext:@"Event 1"];

输出:

Subscriber 1 received: Initial Value
Subscriber 1 received: Event 1

在这个例子中,订阅者 1 在订阅时立即接收到初始值 "Initial Value",并接着收到新事件 "Event 1"。

2. 新的订阅者会收到最后发送的事件

如果有新的订阅者加入,RACBehaviorSubject 会将最新的事件发送给该订阅者:

// 创建一个带初始值的 RACBehaviorSubject
RACBehaviorSubject *behaviorSubject = [RACBehaviorSubject behaviorSubjectWithDefaultValue:@"Initial Value"];

// 发送新事件
[behaviorSubject sendNext:@"Event 1"];

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

// 发送新的事件
[behaviorSubject sendNext:@"Event 2"];

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

输出:

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

在这里,Subscriber 1 收到了 "Event 1" 和 "Event 2"。而 Subscriber 2 订阅时收到了最新的事件 "Event 2"。

3. 用于状态保持的场景

RACBehaviorSubject 非常适合用于状态保持的场景,通常在 UI 中用于保存某个控件的当前状态,并让新加入的观察者立即获取到当前状态:

// 假设我们有一个表示加载状态的 BehaviorSubject
RACBehaviorSubject *loadingStateSubject = [RACBehaviorSubject behaviorSubjectWithDefaultValue:@(NO)];

// 订阅以监听加载状态变化
[loadingStateSubject subscribeNext:^(NSNumber *isLoading) {
    if (isLoading.boolValue) {
        NSLog(@"Loading started");
    } else {
        NSLog(@"Loading ended");
    }
}];

// 开始加载
[loadingStateSubject sendNext:@(YES)];

// 停止加载
[loadingStateSubject sendNext:@(NO)];

输出:

Loading started
Loading ended

RACBehaviorSubject 与其他 Subject 的区别

  • RACSubject:不会缓存事件,新的订阅者无法收到之前发送的事件,只能接收订阅后发送的事件。

  • RACReplaySubject:可以缓存所有事件或指定数量的历史事件,新订阅者会接收到所有缓存的事件。

  • RACBehaviorSubject:只缓存最新的事件,新订阅者会接收到最后一个事件或初始值。

适用场景

  • 状态管理:RACBehaviorSubject 非常适合用于需要保留当前状态的场景,如 UI 控件状态、加载状态等。

  • 单一事件缓存:当只需要缓存并重放最新的事件时,RACBehaviorSubject 是更轻量的选择。

  • 默认初始值:需要指定一个默认值,并保证在没有发送其他事件时,订阅者可以收到初始状态。

总结

RACBehaviorSubject 是一种高效的信号类型,提供了最新事件的缓存和重放功能,适用于需要状态保持的场景。它的行为类似于只保留最新事件的 RACReplaySubject,但具有更简单的实现,适合用作信号的当前状态持有者。

PreviousRACBehaviorSubjectNextRACGroupedSignal

Last updated 8 months ago