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. 疑问
  7. 热信号和冷信号

进一步理解

在 RAC(ReactiveCocoa)中,热信号(Hot Signal)和冷信号(Cold Signal)具有以下特点:

一、热信号

  1. 定义及特点:

    • 热信号一旦被创建就会开始主动发送事件,无论有没有订阅者。它就像一个正在播放的广播电台,持续地发射信号,不受听众是否存在的影响。

    • 多个订阅者订阅同一个热信号时,每个订阅者可能会独立地接收到信号序列中的所有事件,即使在订阅之前已经发送过的事件也可能被接收到。

  2. 应用场景:

    • 适用于表示持续发生的事件流,比如实时的传感器数据、股票价格更新等。这些数据在不断产生,无论有没有人在关注它们。

    • 当需要多个对象同时对一个持续变化的数据源做出反应时,热信号可以方便地实现这种需求,而不需要为每个订阅者单独启动一个数据源。

二、冷信号

  1. 定义及特点:

    • 冷信号只有在有订阅者的时候才会发送事件。它更像是一个按需播放的音乐播放器,只有在有人按下播放键时才会开始播放音乐。

    • 每次有新的订阅者订阅冷信号时,都会重新开始发送事件序列,就好像每个订阅者都得到了一个全新的数据源。

  2. 应用场景:

    • 对于一次性的或者按需触发的操作非常有用,比如用户点击按钮后触发的网络请求。每次用户点击按钮时,都希望得到一个全新的响应,而不是接收之前可能已经发送过的结果。

    • 当需要确保每个订阅者都能独立地控制事件的触发和处理时,冷信号是一个合适的选择。

Previous热信号和冷信号Next信号的发送者和接受者

Last updated 8 months ago