如果我有一个返回承诺的函数并调用另一个也返回承诺的函数,是否可以在不这样做的情况下在两者之间进行转换...
func f1() -> Promise<Any?> { ... }
func f2() -> Promise<Void> {
return f1().then { value -> Void in
...
}
}
如果我没有.then
接听电话,编译器将无法从一种类型转换为另一种类型。
如果我有一个返回承诺的函数并调用另一个也返回承诺的函数,是否可以在不这样做的情况下在两者之间进行转换...
func f1() -> Promise<Any?> { ... }
func f2() -> Promise<Void> {
return f1().then { value -> Void in
...
}
}
如果我没有.then
接听电话,编译器将无法从一种类型转换为另一种类型。
不,首先,泛型在 Swift 中不是协变的。你不能[String]
在你期望的地方传递 a [Any]
,所以你不能从转换Promise<Void>
为Promise<Any?>
。在您的情况下,情况更糟,因为您正在尝试从 to 转换Promise<Any?>
,Promise<Void>
而 aAny?
不是 a Void
。
您可能会认为Void
它有点特别,就像它以一种神奇的编译器方式表示“无”。事实并非如此Void
。它只是空元组 ( ()
) 的类型别名。您无法从 转换Any?
为()
。想象一下,如果你能做到这一点。然后我可以这样写:
var list: [Void] = [] // This is just as legal as Promise<Void>
f2().then { x: Void in
list.append(x)
}
现在我在我的数组中添加了一些随机选项()
。那会崩溃,编译器不会救我。
如果您愿意,您当然可以创建一个助手来执行此操作,例如:
extension Promise {
func ignoringResult() -> Promise<Void> {
return self.then { _ in }
}
}
然后你可以写:
func f2() -> Promise<Void> {
return f1().ignoringResult()
}
PromiseKit 已经有这个转换器:Promise.asVoid()
.