闭包 – 如何使用Swift @autoclosure

我注意到当在Swift中写一个断言,第一个值被键入
@autoclosure() -> Bool

使用重载方法返回通用T值,以通过LogicValue协议测试存在。

但是严格遵守手头的问题。它似乎想要一个返回Bool的@autoclosure。

一个没有参数并返回Bool的实际闭包不起作用,它希望我调用闭包来使其编译,如下所示:

assert({() -> Bool in return false}(),"No user has been set",file: __FILE__,line: __LINE__)

但是简单地通过一个Bool工程:

assert(false,line: __LINE__)

那么发生了什么?什么是@autoclosure?

编辑:@auto_closure已重命名为@autoclosure

考虑一个接受一个参数的函数一个不带参数的简单闭包:
func f(pred: () -> Bool) {
    if pred() {
        print("It's true")
    }
}

调用这个函数,我们必须传入一个闭包

f(pred: {2 > 1})
// "It's true"

如果我们省略括号,我们传入一个表达式,这是一个错误

f(pred: 2 > 1)
// error: '>' produces 'Bool',not the expected contextual result type '() -> Bool'

@autoclosure在表达式周围创建一个自动关闭。所以当调用者写一个类似2> 1,它被自动地封装成一个闭包,成为{2> 1},然后传递给f。因此,如果我们将此应用于函数f:

func f(pred: @autoclosure () -> Bool) {
    if pred() {
        print("It's true")
    }
}

f(pred: 2 > 1)
// It's true

所以它只需要一个表达式,而不需要将它封装在一个闭包。

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...