- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
这些在 ReactiveCocoa 的 Swift 实现和我遇到的任何其他功能性 react 库中大量使用,因此从这个角度来看似乎很有趣。
它本质上看起来是一个包装通用值的结构,但这显然是一种过于简单的解释。这些类型在 swift 标准库中有一些注释,但我发现它们有点太模糊,谷歌搜索结果很少。
最佳答案
我认为将汇视为生成器的对应物会有所帮助。
生成器基本上是 (Void -> T)
的函数, 其中T
是你生成的东西的类型。 GeneratorType
是一个允许结构和类等充当生成器的协议(protocol),方法是给该函数一个名称:next() -> T
.这很方便,因为生成器函数不带参数,所以要生成有用的值序列,您需要一个地方来跟踪调用之间的某些状态。 Generator<T>
是符合 GeneratorType
的通用基类型协议(protocol),你可以继承它来实现你自己的 GeneratorType
.
所以,回到水槽。接收器是生成器的逆函数,这意味着它是 (T -> Void)
的函数。 .它还具有相关协议(protocol) SinkType
,它通过将接收器函数定义为 put(T)
让结构和类充当接收器。 .还有一个基础实现 SinkOf<T>
,您可以直接使用它而无需通过传递 put
的实现来进行子类型化。起到闭包的作用。由于 sink 函数返回 Void
, 它不太可能需要内部状态,但如果你这样做,你可以继承自 SinkOf
或实现 SinkType
在你自己的类/结构上。
所以 SinkOf
并没有完全包装通用值,而是包装了一个采用通用值并对其执行某些操作的函数。在即将到来的 ReactiveCocoa 3 重写中,它们被用来取代 RAC 2 中“订阅者”的概念。
在 RAC 2 中,信号通过调用 sendNext:
来输出事件, sendError:
, 和 sendCompleted
实现 RACSubscriber
的对象的方法协议(protocol)。 RAC 3 用 Event
的接收器替换了单独的方法s,其中 Event<T,ErrorType>
是一个枚举,可以是其中一种情况 .Next(T)
, .Error(ErrorType)
, 和 .Completed
, 再加上新的 .Interrupted
案件。
将所有事件类型包含在一个枚举中可以使信号的含义更加清晰:它是事件流。事件一次到达一个,可以是四种类型之一(RAC2 中为三种)。没有 swift 的 enum
类型,这些事件必须单独调度,因为与事件关联的值类型对于每个事件类型都是不同的。与 enum
s 可以携带不同类型的值,所有你需要实现的 RACSubscriber
是put
的地方Event
,或者换句话说,一个水槽。
这仍然留下了一个问题,即为什么要麻烦拥有一个 SinkType
而不是仅仅传递 (T -> Void)
类型的闭包. The docs只真正谈论编译器优化的好处,但我个人认为它很有用,因为它为您提供了一个可以使用的名称。如果我看到 (T -> Void)
的关闭,我必须暂停一下来解析类型,如果我一直传递它们,就会有很多括号和箭头使我的定义变得困惑。
此外,如果您使用的是生成器,那么它在概念上非常匹配。自 RAC Signal
从概念上讲是事件的生成器,所以从接收器的角度来讨论是有意义的,接收器是生成器的自然补充。
关于swift - 请提供一个实际示例,说明如何/为什么在 Swift(标准库的一部分)中使用 SinkOf 和 SinkType?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26217978/
有没有办法在 .swift 文件(编译成 .swift 模块)中声明函数,如下所示: 你好.swift func hello_world() { println("hello world")
我正在尝试使用 xmpp_messenger_ios 和 XMPPFramework 在 iOS 上执行 MUC 这是加入房间的代码。 func createOrJoinRoomOnXMPP()
我想在我的应用程序上创建一个 3D Touch 快捷方式,我已经完成了有关快捷方式本身的所有操作,它显示正确,带有文本和图标。 当我运行这个快捷方式时,我的应用程序崩溃了,因为 AppDelegate
我的代码如下: let assetTag = Expression("asset_tag") let query2 = mdm.select(mdm[assetTag],os, mac, lastRe
我的 swift 代码如下所示 Family.arrayTuple:[(String,String)]? = [] Family.arrayTupleStorage:String? Family.ar
这是我的 JSON,当我读取 ord 和 uniq 数据时出现错误 let response2 : [String: Any] = ["Response":["status":"SUCCESS","
我想将 swift 扩展文件移动到 swift 包中。但是,将文件移动到 swift 包后,我遇到了这种错误: "Type 'NSAttributedString' has no member 'ma
使用CocoaPods,我们可以设置以下配置: pod 'SourceModel', :configurations => ['Debug'] 有什么方法可以用 Swift Package Manag
我正在 Xcode 中开发一个 swift 项目。我将其称为主要项目。我大部分都在工作。我在日期选择器、日期范围和日期数学方面遇到了麻烦,因此我开始了另一个名为 StarEndDate 的项目,其中只
这是 ObjectiveC 代码: CCSprite *progress = [CCSprite spriteWithImageNamed:@"progress.png"]; mProgressBar
我正在创建一个命令行工具,在 Xcode 中使用 Swift。我想使用一个类似于 grunt 的配置文件确实如此,但我希望它是像 Swift 包管理器的 package.swift 文件那样的快速代码
我假设这意味着使用系统上安装的任何 swift 运行脚本:#!/usr/bin/swift 如何指定脚本适用的解释器版本? 最佳答案 Cato可用于此: #!/usr/bin/env cato 1.2
代码说完全没问题,没有错误,但是当我去运行模拟器的时候,会出现这样的字样: (Swift.LazyMapCollection (_base:[ ] 我正在尝试创建一个显示报价的报价应用。 这是导入
是否可以在运行 Swift(例如 Perfect、Vapor、Kitura 等)的服务器上使用 RealmSwift 并使用它来存储数据? (我正在考虑尝试将其作为另一种解决方案的替代方案,例如 no
我刚开始学习编程,正在尝试完成 Swift 编程书中的实验。 它要求““编写一个函数,通过比较两个 Rank 值的原始值来比较它们。” enum Rank: Int { case Ace = 1 ca
在您将此问题标记为重复之前,我检查了 this question 它对我不起作用。 如何修复这个错误: error: SWIFT_VERSION '5.0' is unsupported, suppo
从 Xcode 9.3 开始,我在我的模型中使用“Swift.ImplicitlyUnwrappedOptional.some”包裹了我的字符串变量 我不知道这是怎么发生的,但它毁了我的应用程序! 我
这个问题在这里已经有了答案: How to include .swift file from other .swift file in an immediate mode? (2 个答案) 关闭 6
我正在使用 Swift Package Manager 创建一个应用程序,我需要知道构建项目的配置,即 Debug 或 Release。我试图避免使用 .xcodeproj 文件。请有人让我知道这是否
有一个带有函数定义的文件bar.swift: func bar() { println("bar") } 以及一个以立即模式运行的脚本foo.swift: #!/usr/bin/xcrun s
我是一名优秀的程序员,十分优秀!