@noescape优化编译器编译,swift 2.1引入。
函数如果有一个一个参数是closure的话,可以在前面加一个关键字@noescape表示在函数return前closure生命周期结束,可以优化编译。(closure 是引用类型,可以引用到别的地方,如下:)
class A{ var b: (VoID -> VoID)! func lalala(a: (VoID->VoID)){ self.b = a//引用到属性b了 }}
像上面的情况lalala的参数a是不能在前面标记@noescape
class A{ var b: (VoID -> VoID)! func aa(@noescape a: (VoID->VoID)){ self.b = a//会报错,报类型不一样 }}
而没有引用到外层的closure可以加@noescape例如
class A{ var b: (VoID -> VoID)! func aa(@noescape a: (VoID->VoID)){ a()//不会报错,这个不会再外部再次被调用 }}
@noescape 还有个特性就是标记了 @noescape的closure可以免去写引用self。swift的普通closure使用self时都需要。这个可以例外。因为他相当于一个同步的调用,不会产生循环引用,所以不用特意强调self
class A{ var b: (VoID -> VoID)! var k = 0//用来调用的 func aa(@noescape a: (VoID->VoID)){ a() } func bb(){ aa { () -> VoID in k = 1//一般的closure都是要self.k = 1,@noescape则不需要 } }}
讨论:啥时候会用到@noescape?现在很多函数式编程,比如有个排序,需要一个比较的closure作为参数,这种closure都会是同步调用完毕获得返回值。这种可以放一个@noescape在前面,可优化内存,引用self不必写self。其他的closure在外部引用着等待将来回掉用的则不能@noescape,因为它会escape。总体来说这个@noescape没啥卵用,但是有些人会用,可能会吓到你。比如我昨天就看到一个用了这个的,这个基本可以无视。苹果文档链接
总结以上是内存溢出为你收集整理的Swift2.1关键字 @noescape介绍全部内容,希望文章能够帮你解决Swift2.1关键字 @noescape介绍所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)