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. RACSignal
  7. 常用的方法

concat:

在 ReactiveCocoa 中,concat: 方法用于将多个信号串联成一个信号,以顺序执行的方式依次发出每个信号的值。只有当前一个信号完成(completed)后,concat: 才会开始下一个信号。这种方法特别适用于希望严格控制多个异步任务的执行顺序的场景。

基本用法

以下是 concat: 的使用步骤:

  1. 创建多个信号:这些信号表示一系列任务或事件。

  2. 串联信号:使用 concat: 将多个信号串联成一个信号。

  3. 订阅串联后的信号:订阅结果信号,将按照顺序接收到每个信号的值。

示例:将多个信号串联

假设我们有两个信号 signal1 和 signal2,希望在 signal1 完成后再执行 signal2。

// 创建第一个信号
RACSignal *signal1 = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
    [subscriber sendNext:@"来自信号 1"];
    [subscriber sendCompleted];
    return nil;
}];

// 创建第二个信号
RACSignal *signal2 = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
    [subscriber sendNext:@"来自信号 2"];
    [subscriber sendCompleted];
    return nil;
}];

// 使用 concat 将两个信号串联
RACSignal *concatenatedSignal = [signal1 concat:signal2];

// 订阅串联后的信号
[concatenatedSignal subscribeNext:^(id x) {
    NSLog(@"接收到: %@", x);
} completed:^{
    NSLog(@"所有信号都已完成.");
}];

输出

接收到: 来自信号 1
接收到: 来自信号 2
所有信号都已完成.

在这个例子中,signal1 会首先发出值 @"来自信号 1",完成后 signal2 再发出值 @"来自信号 2"。

注意事项

  • 执行顺序:concat: 按顺序依次执行每个信号,前一个信号必须完成后,才会触发下一个信号。

  • 适用场景:适用于需要串行执行的异步操作,例如网络请求、文件下载或依赖性任务。

  • 与 merge: 区别:merge: 会并行地订阅多个信号,并发地接收它们的值;而 concat: 是串行的,确保前一个信号完成后才开始下一个信号。

高级示例:多个信号串联

假设我们有三个信号,希望将它们依次串联,并且希望每个信号都完成后才执行下一个信号:

RACSignal *signal1 = [RACSignal return:@"值 1"];
RACSignal *signal2 = [RACSignal return:@"值 2"];
RACSignal *signal3 = [RACSignal return:@"值 3"];

// 串联三个信号
RACSignal *concatenatedSignal = [[signal1 concat:signal2] concat:signal3];

// 订阅串联信号
[concatenatedSignal subscribeNext:^(id x) {
    NSLog(@"接收到: %@", x);
} completed:^{
    NSLog(@"所有信号都已完成.");
}];

输出

接收到: 值 1
接收到: 值 2
接收到: 值 3
所有信号都已完成.

在这个例子中,每个信号会依次发出它的值,保证了严格的顺序执行。

总结

  • concat: 是一个串联信号的方法,用于确保按顺序执行一系列异步任务。

  • 它只有在前一个信号完成后,才会开始执行下一个信号,适合需要严格执行顺序的场景。

  • 可以结合多个 concat: 使用,创建一个多信号的顺序执行链。

concat: 在控制多个任务的顺序上非常有用,

Previous常用的方法Nextbind:

Last updated 8 months ago