欢迎来到代码驿站!

iOS代码

当前位置:首页 > 移动开发 > iOS代码

iOS开发中Swift逃逸闭包知识

时间:2021-05-13 08:11:37|栏目:iOS代码|点击:

逃逸闭包必须满足下面2个条件:

1、闭包作为一个参数传到函数中

2、闭包在函数返回之后才执行

需要在参数前面加入标注: @escaping,用来指明这个闭包是允许“逃逸”出这个函数的。

注意:将一个闭包标记为 @escaping 意味着你必须在闭包中显式地引用

import UIKit

/** 逃逸闭包满足下面2个条件:
 * 1、handle闭包作为一个参数传到函数payRequest中
 * 2、并且handle闭包在函数返回之后才执行
 * 需要在参数前面加入标注: @escaping,用来指明这个闭包是允许“逃逸”出这个函数的
 * 注意:将一个闭包标记为 @escaping 意味着你必须在闭包中显式地引用 self
 */
func payRequest(handle:@escaping (Data?, URLResponse? ,Error?) -> Void) {
  let urlStr = URL(string: "http://www.baidu.com")
  let session = URLSession(configuration: .default)
  session.dataTask(with: urlStr!, completionHandler: handle)
}
func someFunctionWithNonescapingClosure(closure: () -> Void) {
  closure()
}
class SomeClass {
  var x = 10
  func doSomething() {
    payRequest { (data, resp, error) in
      x = 100 // 此处编译错误,必须显式地引用 self
    }
    someFunctionWithNonescapingClosure { x = 200 }
  }
}

在Swift标准库中,有很多这种类型的闭包,比如下面的异步请求的方法:

open func dataTask(with request: URLRequest, completionHandler: @escaping (Data?, URLResponse?, Error?) -> Swift.Void) -> URLSessionDataTask

open func dataTask(with url: URL, completionHandler: @escaping (Data?, URLResponse?, Error?) -> Swift.Void) -> URLSessionDataTask

都符合文章开头提到的逃逸闭包的形成条件。

上一篇:iOS App使用GCD导致的卡顿现象及解决方法

栏    目:iOS代码

下一篇:iOS设计模式――Category简单介绍

本文标题:iOS开发中Swift逃逸闭包知识

本文地址:http://www.codeinn.net/misctech/120248.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有