闭包-简洁版(Swift)

来源:互联网 发布:秀萝捏脸数据 编辑:程序博客网 时间:2024/05/17 13:41

转自:http://ju.outofmemory.cn/entry/103446

闭包内容挺多的,一次看多了晕菜,直接来个简洁版的,还有疑惑看其他帖子去

  1. 闭包(closure)与函数(function)
    很多语言都有闭包的概念,比如C中的block,C++的lamda //Global functions, nested functions, and closure 可以认为函数是特殊形式的闭包,也可以认为闭包是匿名函数,二者基本是通用的。
    无论函数还是闭包,在引用外部变量时,如果变量是在栈上(比如,局部变量),会将其拷贝到堆上,这也是所有语言中的做法。
    1. Global function

       var c = 1 func inc() -> Int {     return ++c }
    2. Nested function

       func makeIncrementor() -> (()->(Int)){     var c = 1     func inc() -> Int {         c++         return c     }     return inc }  
    3. Closure

       func makeIncrementor(var c:Int) -> (()->(Int)){     var c = 1     return { () -> Int in         c++         return c     } }
  2. 闭包的基本形式

     { (parameters) -> (return type) in     statements } let reversed = sort(["Jim", "Kate"], { (s1:String, s2:String) -> Bool in     return s1 > s2     })// 闭包的函数体部分由关键字 in 引入// 该关键字表示闭包的参数和返回值类型定义已经完成,闭包的函数体即将开始
  3. 类型推导
    可以由上下文推导传入和传出的参数类型,比如sort的原型是 func sort(array: T[], pred: (T, T) –> Bool) –> T[]
    根据第一个String[]就可以知道s1, s2是String类型了,返回值s1>s2自然是Bool类型

     let reversed2 = sort(["Jim", "Kate"], { s1, s2 in     let a = s1.utf16count     return s1 > s2     })
  4. 如果只有一条语句的话,return可省略,直接将该语句的值返回,但多条语句return不能省略

     let reversed3 = sort(["Jim", "Kate"], { s1, s2 in     s1 > s2     })
  5. 如果不写参数名称,默认是$0, $1,…

     let reversed4 = sort(["Jim", "Kate"], {     $0 > $1     })
  6. 在这里还可以直接使用运算符函数operator function

     let reversed5 = sort(["Jim", "Kate"], >)
  7. 跟function一样,closure的参数默认为let,可以使用var修改

  8. closure是reference type

0 0
原创粉丝点击