@autoclosure和@noescape和@escape

1:自动闭包,顾名思义是一种自动创建的闭包,用于包装函数参数的表达式,可以说是一种简便语法.

2:自动闭包不接受任何参数,被调用时会返回被包装在其中的表达式的值。

3:自动闭包的好处之二是让你能够延迟求值,因为代码段不会被执行直到你调用这个闭包,这样你就可以控制代码什么时候执行。

4:含有autoclosure特性的声明同时也具有noescape的特性,及默认是非逃逸闭包,除非传递可选参数escaping.如果传递了该参数,那么将可以在闭包之外进行操作闭包,形式为:请使用@autoclosure(escaping)。

func printIfTrue(predicate: ()-> Bool){

if predicate(){

print("the result is true")

}

}

//1直接调用方法

printIfTrue { () -> Bool in

return 2 > 1

}

//2闭包在圆括号内

printIfTrue(predicate: { return 2 > 1 })

//3:使用尾部闭包方式,闭包体在圆括号之外

printIfTrue(){ return 2 > 1 }

//4:在 Swift 中对闭包的用法可以进行一些简化,在这种情况下我们可以省略掉 return,写成:

printIfTrue(predicate: { 2 > 1})

//5:还可以更近一步,因为这个闭包是最后一个参数,所以可以使用尾随闭包 (trailing closure) 的方式把大括号拿出来,然后省略括号,变成:

printIfTrue{2 > 1}

但是不管哪种方式,表达上不太清晰,看起来不舒服。于是@autoclosure就登场了。我们可以改换方法参数,在参数名前面加上@autoclosure关键字:

func printIfTrue( predicate: @autoclosure ()-> Bool){

if predicate(){

print("the result is true")

}

}

printIfTrue( predicate:2 > 1 )

@noescape属性是在 Swift1.2中引入的,把传入闭包参数的调用限制在调用的函数体内,对性能有一定的提升

默认情况下,闭包是@escape的。表示此闭包还可以被其他闭包调用。

isKindOfClass 可以判断某对象是否是某个类的实例对象,这个类和这个类的继承类都可以判断;

而isMemberOfClass只能判断对象是否是当前类的实例对象。

如果我们遇到了多重 Optional 的麻烦的时候,这显然对我们是没有太大帮助的。我们可以使用 fr v -R 命令来打印出变量的未加工过时的信息。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容