转自:http://ju.outofmemory.cn/entry/103446
闭包内容挺多的,一次看多了晕菜,直接来个简洁版的,还有疑惑看其他帖子去
- 闭包(closure)与函数(function)
很多语言都有闭包的概念,比如C中的block,C++的lamda //Global functions,nested functions,and closure 可以认为函数是特殊形式的闭包,也可以认为闭包是匿名函数,二者基本是通用的。
无论函数还是闭包,在引用外部变量时,如果变量是在栈上(比如,局部变量),会将其拷贝到堆上,这也是所有语言中的做法。-
Global function
var c = 1 func inc() -> Int { return ++c }
-
Nested function
func makeIncrementor() -> (()->(Int)){ Int { c++ return c } return inc }
-
Closure
func makeIncrementor(var c:Int) -> (()->(1 return { () -> Int in c++ return c } }
-
-
闭包的基本形式
{ (parameters) -> (return type) in statements } let reversed = sort(["Jim", "Kate"], { (s1:String, s2:String) -> Bool in return s1 > s2 })// 闭包的函数体部分由关键字 in 引入// 该关键字表示闭包的参数和返回值类型定义已经完成,闭包的函数体即将开始
-
类型推导
可以由上下文推导传入和传出的参数类型,比如sort的原型是 func sort(array: T[],pred: (T,T) –> Bool) –> T[]
根据第一个String[]就可以知道s1,s2是String类型了,返回值s1>s2自然是Bool类型let reversed2 = sort([ { s1, s2 let a = s1.utf16count return s1 > s2 })
-
如果只有一条语句的话,return可省略,直接将该语句的值返回,但多条语句return不能省略
let reversed3 = sort([in s1 > s2 })
-
如果不写参数名称,默认是$0,$1,…
let reversed4 = sort([ { $0 > $1 })
-
在这里还可以直接使用运算符函数operator function
let reversed5 = sort([ >)
-
跟function一样,closure的参数默认为let,可以使用var修改
- closure是reference type