第九章 闭包 - Closures.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
闭包 - Closures 闭包 (Closures) 闭包是⾃包含的函数代码块,可以在代码中被传递和使⽤。Swift 中的闭包与 C 和 Objective-C 中的代码块 (blocks )以及其他⼀些 程语⾔中的 lambdas 函数⽐较相 似。 闭包可以捕获和存储其所在上下⽂中任意常量和变量的引⽤。这就是所谓的闭合并包 裹着这些常量和变量,俗称闭包。Swift 会为您管理在捕获过程中涉及到的所有内存 操作。 注意:如果您不熟悉捕获 (capturing )这个概念也不⽤担⼼,您可以在 值捕获 章节对其进⾏详细了解。 在函数 章节中介绍的全局和嵌套函数实际上也是特殊的闭包,闭包采取如下三种形式 之⼀: 全局函数是⼀个有名字但不会捕获任何值的闭包 嵌套函数是⼀个有名字并可以捕获其封闭函数域内值的闭包 闭包表达式是⼀个利⽤轻量级语法所写的可以捕获其上下⽂中变量或常量值的 匿名闭包 Swift 的闭包表达式拥有简洁的风格,并⿎励在常见场景中进⾏语法优化,主要优化 如下: 利⽤上下⽂推断参数和返回值类型 隐式返回单表达式闭包,即单表达式闭包可以省略return关键字 参数名称缩写 尾随 (Trailing )闭包语法 闭包表达式 (Closure Expressions) 嵌套函数 是⼀个在较复杂函数中⽅便进⾏命名和定义⾃包含代码模块的⽅式。当然, 有时候撰写⼩巧的没有完整定义和命名的类函数结构也是很有⽤处的,尤其是在您处 理⼀些函数并需要将另外⼀些函数作为该函数的参数时。 闭包表达式是⼀种利⽤简洁语法构建内联闭包的⽅式。闭包表达式提供了⼀些语法优 化,使得撰写闭包变得简单明了。下⾯闭包表达式的例⼦通过使⽤⼏次迭代展⽰了 sorted函数定义和语法优化的⽅式。每⼀次迭代都⽤更简洁的⽅式描述了相同的功 能。 sorted 函数 (The Sorted Function ) Swift 标准库提供了sorted函数,会根据您提供的基于输出类型排序的闭包函数将已 知类型数组中的值进⾏排序。⼀旦排序完成,函数会返回⼀个与原数组⼤⼩相同的新 数组,该数组中包含已经正确排序的同类型元素。 下⾯的闭包表达式⽰例使⽤sorted函数对⼀个String类型的数组进⾏字母逆序排 序,以下是初始数组值: let names = [Chris, Alex, Ewa, Barry, Daniella] sorted函数需要传⼊两个参数: 已知类型的数组 闭包函数,该闭包函数需要传⼊与数组类型相同的两个值,并返回⼀个布尔类 型值来告诉sorted函数当排序结束后传⼊的第⼀个参数排在第⼆个参数前⾯ 还是后⾯。如果第⼀个参数值出现在第⼆个参数值前⾯,排序闭包函数需要返 回true,反之返回false。 该例⼦对⼀个String类型的数组进⾏排序,因此排序闭包函数类型需为(String, String - Bool。 提供排序闭包函数的⼀种⽅式是撰写⼀个符合其类型要求的普通函数,并将其作 为sort函数的第⼆个参数传⼊: func backwards(s1: String, s2: String - Bool { return s1 s2 } var reversed = sorted(names, backwards // reversed 为 [Ewa, Daniella, Chris, Barry, Alex] 如果第⼀个字符串 (s1) ⼤于第⼆个字符串 (s2) ,backwards函数返回true,表⽰在 新的数组中s1应该出现在s2前。对于字符串中的字符来说,“⼤于” 表⽰ “按照字母顺 序较晚出现” 。这意味着字母B⼤于字母A,字符串Tom⼤于字符串Tim。其 将进⾏字母逆序排序,Barry将会排在Alex之前。 然⽽,这是⼀个相当冗长的⽅式,本质上只是写了⼀个单表达式函数 (a b) 。在下⾯ 的例⼦中,利⽤闭合表达式语法可以更好的构造⼀个内联排序闭包。 闭包表达式语法 (Closure Expression Syntax ) 闭包表达式语法有如下⼀般形式: { (parameters - returnType in stateme

文档评论(0)

0520 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档