闭包 – 如何使用Swift @autoclosure
发布时间:2020-12-14 06:16:05 所属栏目:百科 来源:网络整理
导读:我注意到当在Swift中写一个断言,第一个值被键入 @autoclosure() - Bool 使用重载方法返回通用T值,以通过LogicValue协议测试存在。 但是严格遵守手头的问题。它似乎想要一个返回Bool的@autoclosure。 写一个没有参数并返回Bool的实际闭包不起作用,它希望我
我注意到当在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 所以它只需要一个表达式,而不需要将它封装在一个闭包。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- ruby-on-rails – 当资源型号名称与路径或控制器不匹配时,如
- reactjs – React Navigation Header随屏幕变化
- UIWebView Javascript窗口到窗口通信
- xml文件编辑卡的问题
- ruby-on-rails – 在heroku上为rails 3.1 app启用浏览器端缓
- ruby-on-rails – 没有动作的表单Ruby on Rails
- 指针变量是什么,C++指针变量详解
- flash – html5视频支持flv开箱即用的手机(symbian,android
- .Net 4.5是否支持XML 1.1(对于XML 1.0中无效的字符)?
- 在Swift工程中使用OC