Bic*_*ops 4 closures functional-programming swift
我试图理解map函数使用的一些简写语法.
以下是设置
let array = [1, 2, 3]
// these make sense
let arr1 = array.map({String($0)})
let arr2 = array.map{String($0)}
let arr3 = array.map({ number in
return String(number)
})
let arr4 = array.map({ (number) -> String in
String(number)
})
Run Code Online (Sandbox Code Playgroud)
这是混乱的地方.在swift中,我可以放弃地图的花括号,但这似乎是无法完成的事情,对于我自己的函数,我有一个尾随闭包.可能会做出一些神奇的推论吗?同样为什么String以这种方式初始化?
// this doesn't make sense. Foregoing the curly braces? I can't do that!!!
let arr5 = array.map(String.init)
let arr6 = array.map(String()) // Compile Error: Cannot convert value of type 'String' to expected argument type '@noescape (Int) throws -> _'
Run Code Online (Sandbox Code Playgroud)
这是我尝试使用类似于map的语法
func crap(block:(Int)-> String) {
print("Int to string block" + block(1));
}
// works obviously
crap{ "\($0) some garbage" }
// compile error : Anonymous closure argument not contained in a closure
crap( "\($0) some garbage" )
Run Code Online (Sandbox Code Playgroud)
区分括号()与花括号{}.
从某种意义上说,只有括号版本才是"真实的",因为毕竟这就是函数调用所需要的.在你打电话的括号中map,你放了一个函数.它可能是一个函数引用(即函数的名称):
let arr = [1,2,3]
func double(i:Int) -> Int {return i*2}
let arr2 = arr.map(double)
Run Code Online (Sandbox Code Playgroud)
或者它可以是一个匿名函数,意味着大括号中的函数体:
let arr = [1,2,3]
let arr2 = arr.map({$0*2})
Run Code Online (Sandbox Code Playgroud)
但在这种情况下,只有这种情况,你可以(作为一个快捷方式)使用"尾随闭包"语法:
let arr = [1,2,3]
let arr2 = arr.map(){$0*2}
Run Code Online (Sandbox Code Playgroud)
但是,由于map不带任何其他参数,就可以还省略括号-斯威夫特唯一的情况下,你可以调用一个函数不使用括号:
let arr = [1,2,3]
let arr2 = arr.map{$0*2}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
856 次 |
| 最近记录: |