微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Swift的学习(闭包2续)

2、尾随闭包 (Trailing Closures) 语法不同而已,意思是一致的; 最后一个参数是函数,及闭包时,及尾随闭包;当你的函数里有一个参数 是函数,并且描述很长,这时你可以将其放在参数的最后;及尾随闭包

//定义了一个函数 两个参数,后一个函数
func someFunctionThatTakesAClosures(params1:String,params2:()->Void) { print(params1) params2() } //正常语法的使用 someFunctionThatTakesAClosures("hello",params2: { print("正常调用") }) //尾随闭包的使用 someFunctionThatTakesAClosures("你好") { print("尾随闭包调用") }
//如果只有闭包 一个参数,此函数 在使用时()可以省去
func testTrailing(params:()->Void) { params() } testTrailing { print("测试只有一个闭包参数的函数") }
//尾随闭包的练习
let digitName=[0:"zero",1:"one",2:"two",3:"three",4:"four",5:"five"]
let numberArray=[14,22,123]
let resultC=numberArray.map { (resultA) -> String in
    var resultA=resultA
    print(resultA)
    return "你好\(resultA)"
}
print(resultC)//结果 ["你好14","你好22","你好123"]
let resultD=digitName.map { (key,value) -> Void in
    print(key,value)
}
print(resultD)//结果 [(),(),()]

//有些理解只可意会,不可言传;通过这个例子大家自己对他理解吧

3、捕获值 (Captureing Values) 可以理解为在内部函数能够访问传进去的值

func makeIncrementer(params amcount:Int) -> ()->Int {

    var runningToal=0
    func incrementer()->Int{

      runningToal+=amcount
        return runningToal
    }
    return incrementer

}

  var resultI=makeIncrementer(params: 10)
   print(resultI(),resultI(),resultI())//结果 10 20 30

//incrementer()单独拿出来是没有意义的

4闭包是引用类型

let also=resultI
   print(also())//结果 40

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐