闭包中的隐式返回导致错误

闭包中的隐式返回导致错误,第1张

闭包中的隐式返回导致错误

任何建议都不确定如何在没有虚拟return语句的情况下处理上述问题。

您已经很好地解决了问题。匿名函数自动使用单行函数主体作为返回值,因此,要防止这种情况导致类型与预期返回类型(Void)不匹配,您必须添加另一行代码,以使其
不是 单行函数身体。伪返回语句本身返回Void,是处理它的 方法。我会用它继续前进。有一些时髦的解决方法,但是您所拥有的正是我会做的。

编辑:要了解类型不匹配的来源,请尝试以下 *** 作:

struct Test {    func voider() -> Void {}}let testMaybe = Optional(Test())let result = testMaybe?.voider()

现在

result
不是虚空了;这是包装空心的可选。那就是你正在发生的事。一个空值是预期的,但您的单行匿名函数返回一个包装空值的Optional。通过添加另一条显式返回Void的行,您解决了该问题。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5620101.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-15
下一篇 2022-12-15

发表评论

登录后才能评论

评论列表(0条)

保存