本节主要叙述的是闭包的几种形式,以及闭包的实际作用,闭包是一种自包含的函数代码块, 可以在代码中被传递和使用,闭包类似于C++中的Lambda 表达式,那么我们先来看看C++中Lambda 是怎么回事。先看一段简单的代码:
int x = 10; int y = 3; int z ; z = [=]()mutable throw() -> int { int n = x + y; x = y; y = n; return n; }(); cout<<z<<endl; cout<<"x:"<<x<<"\t"<<"y:"<<y<<endl;Lambda表达式的引入标志,在‘[]’里面可以填入‘=’或‘&’表示该lambda表达式“捕获”(lambda表达式在一定的scope可以访问的数据)的数据时以什么方式捕获的,‘&’表示一引用的方式;‘=’表明以值传递的方式捕获,除非专门指出。 Lambda表达式的参数列表 Mutable 标识 异常标识 返回值 函数”体,也就是lambda表达式需要进行的实际 *** 作
这个C++是lambda表达式的一个基本逻辑。那么Swift闭包又是怎么回事呢。我们也想来看一段代码。
let names = ["Chris","Alex","Ewa","barry","DanIElla"]reversed = sorted(names,{ (s1: String,s2: String) -> Bool in return s1 > s2 })
从这段简单的代码中我们可以看到swift中闭包具有以下格式:
{ (parameters) -> returnType in statements}
parameters是输出参数;returnType 是返回值类型;statements是执行代码。注意:在闭包中有一个关键字in,该关键字表示闭包的参数和返回值类型定义已经完成, 闭包函数体即将开始。这个是基本的swift闭包形式,
根据上下文推断类型闭包reversed = sorted(names,{s1,s2 in return s1 > s2})
根据上下文推断类型闭包可以是推断输出参数,输出类型。
单表达式闭包隐式返回reversed = sorted(names,{ s1,s2 in s1 > s2 } )
这种闭包形式就更加简洁,将return都省略了。
参数名称缩写reversed = sorted(names,{ > } )
这种闭包简写简直让人吐血,什么都是省略类:0
sorted(names,>)=(closure: () -> ())
这种闭包缩写让人看了以为代码写错了。简直无语,这也体现类swift的精简。
尾随闭包如果您需要将一个很长的闭包表达式作为最后一个参数传递给函数, 可以使用尾随闭包来增强函数的可读性。 尾随闭包是一个书写在函数括号之后的闭包表达式, 函数支持将其作为最后一个参数调用。
func someFunctionThatTakesAClosuresomeFunctionThatTakesAClosure { // 函数体部分 } // 以下是不使用尾随闭包进行函数调用 //({ someFunctionThatTakesAClosure 闭包主体部分 }) // 以下是使用尾随闭包进行函数调用 () { // 闭包主体部分 }
将上面的闭包形式用尾随闭包来写,如下:
reversed = sorted(names) { > }
尾随闭包看起来就像Java中方法实现一样。这个对于我来说是很不习惯的,但是如果闭包代码比较多,尾随闭包却很有用,他可以代码看起来更加简洁。 至此,swift中所有的闭包形式就描述完了。但是swift闭包可以捕获和存储其所在上下文中任意常量和变量的引用。而不像C++中需要制定访问参数和访问类型等。
总结以上是内存溢出为你收集整理的Swift学习笔记——闭包的几种形式全部内容,希望文章能够帮你解决Swift学习笔记——闭包的几种形式所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)