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

内容

RACGroupedSignal 是 ReactiveCocoa 中的一个辅助类型,通常作为 groupBy: 操作符的结果出现,用于将一个信号的事件按照某种特定的规则进行分组。分组后的信号通过 RACGroupedSignal 传递,每个 RACGroupedSignal 实例表示一个特定的分组,订阅者可以根据分组进行进一步的事件处理。

RACGroupedSignal 的特点

  1. 分组标识:RACGroupedSignal 包含一个 key 属性,表示当前分组的标识,通常是根据某个条件(如对象属性、值等)生成的。

  2. 基于 groupBy: 操作生成:RACGroupedSignal 由信号的 groupBy: 操作生成,通常是对原始信号的元素进行分类后生成的分组信号。

  3. 同一分组:在同一个 RACGroupedSignal 实例中,所有的事件都是属于同一个分组的。

  4. 独立处理:每个 RACGroupedSignal 可以独立地进行处理和订阅,支持对不同分组进行差异化处理。

groupBy: 操作生成 RACGroupedSignal

groupBy: 操作符用于将一个信号的元素按特定的键分组,并返回一个信号,该信号会发送 RACGroupedSignal 类型的事件。每个 RACGroupedSignal 实例代表一个特定的分组,且包含一个唯一的 key。

使用示例

以下示例展示了如何使用 groupBy: 将一个信号的事件按条件进行分组,并对不同分组的信号进行处理。

1. 基本使用

假设有一个信号 numbersSignal,发送一组整数。我们可以通过 groupBy: 将这些整数按奇偶分组,并对不同的分组进行处理:

// 创建一个信号,发送一组整数
RACSignal *numbersSignal = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
    [subscriber sendNext:@1];
    [subscriber sendNext:@2];
    [subscriber sendNext:@3];
    [subscriber sendNext:@4];
    [subscriber sendCompleted];
    return nil;
}];

// 使用 groupBy: 将信号按奇偶分组
RACSignal *groupedSignal = [numbersSignal groupBy:^id(NSNumber *number) {
    return (number.intValue % 2 == 0) ? @"Even" : @"Odd";
}];

// 订阅分组信号
[groupedSignal subscribeNext:^(RACGroupedSignal *groupedSignal) {
    NSLog(@"Group: %@", groupedSignal.key);
    
    // 针对每个分组的信号进行订阅
    [groupedSignal subscribeNext:^(id x) {
        NSLog(@"%@ Group - Value: %@", groupedSignal.key, x);
    }];
}];

输出:

Group: Odd
Odd Group - Value: 1
Odd Group - Value: 3
Group: Even
Even Group - Value: 2
Even Group - Value: 4

在这个例子中,numbersSignal 按奇偶性分成了 Odd 和 Even 两个分组,groupBy: 为每个分组生成了一个 RACGroupedSignal,我们可以根据 key(Odd 和 Even)识别不同的分组并分别处理每个组内的事件。

2. 针对不同分组做不同的处理

使用 RACGroupedSignal 的 key 属性,可以根据分组做出不同的反应:

[groupedSignal subscribeNext:^(RACGroupedSignal *groupedSignal) {
    if ([groupedSignal.key isEqualToString:@"Odd"]) {
        [groupedSignal subscribeNext:^(id x) {
            NSLog(@"Odd Number: %@", x);
        }];
    } else if ([groupedSignal.key isEqualToString:@"Even"]) {
        [groupedSignal subscribeNext:^(id x) {
            NSLog(@"Even Number: %@", x);
        }];
    }
}];

输出:

Odd Number: 1
Odd Number: 3
Even Number: 2
Even Number: 4

在这里,通过 key 判断分组类型,并对 Odd 和 Even 组进行不同的处理。

总结

  • RACGroupedSignal 用于 groupBy: 操作后的信号分组,包含一个 key 标识分组。

  • 每个 RACGroupedSignal 实例代表一个特定的分组,所有分组事件都通过这个分组信号传递。

  • 可以基于 key 属性对不同的分组做出不同处理,从而实现对信号流的精细化管理。

RACGroupedSignal 非常适合在需要根据特定条件对信号进行分组和分类处理的场景中使用,例如按用户类型、数据属性等条件对事件流进行逻辑分流。

PreviousRACGroupedSignalNextRACDynamicSignal

Last updated 8 months ago