加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Swift-非逃逸闭包

发布时间:2020-12-14 07:19:19 所属栏目:百科 来源:网络整理
导读:非逃逸闭包//当一个闭包作为参数传到一个函数中,但是这个闭包在函数返回之后被执行,我们称该闭包从函数中逃逸。当你定义接受闭包作为参数的函数时,可以在参数名之前标注@noescape,用来指明这个闭包是不允许“逃逸”出这个函数的。//将闭包标注@noescape能
非逃逸闭包
//当一个闭包作为参数传到一个函数中,但是这个闭包在函数返回之后被执行,我们称该闭包从函数中逃逸。当你定义接受闭包作为参数的函数时,可以在参数名之前标注@noescape,用来指明这个闭包是不允许“逃逸”出这个函数的。
//将闭包标注@noescape能使编译器知道这个闭包的生命周期
//注:闭包只能在函数体中被执行,不能脱离函数体执行
func someFunctionWithNoescapeClosure(@noescape closure: () -> Void) {
    closure()
}



//一种能使闭包“逃逸”出函数的方法是,将这个闭包保存在一个函数外部定义的变量中。这种情况下,闭包需要“逃逸”出函数,因为闭包需要在函数返回之后被调用。
//例:
var completionHandlers: [() -> Void] = []
func someFunctionWithEscapingClosure(completionHandler: () -> Void) {
    completionHandlers.append(completionHandler)
}



//someFunctionWithEscapingClosure()函数接受一个闭包作为参数,该闭包被添加到一个函数外定义的数组中。
//若你要是将这个参数标注为@noescape,你将会获得一个编译错误

//将闭包标注为@noescape使你能在闭包中隐式的引用self

class SomeClass {
    var x = 10
    func doSomething() {
   
        someFunctionWithEscapingClosure { self.x = 100 }
        someFunctionWithNoescapeClosure { x = 200 }
        
        
    }
}

let instance = SomeClass()
instance.doSomething()
print(instance.x)


completionHandlers.first?()
print(instance.x)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读