我注意到当在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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。