我正在尝试理解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)
})
这是混乱的所在。在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 -> _'
这是我尝试使用与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" )
答案 0 :(得分:7)
将括号()
与花括号{}
区分开来。
从某种意义上说,只有括号版本才是“真实的”,因为毕竟这就是函数调用所需要的。在调用map
时,在括号中添加了一个函数。它可以是函数 reference (即函数的名称):
let arr = [1,2,3]
func double(i:Int) -> Int {return i*2}
let arr2 = arr.map(double)
或者它可以是一个匿名函数,意思是大括号中的函数体:
let arr = [1,2,3]
let arr2 = arr.map({$0*2})
但是在那个的情况下,只有那种情况,你可以(作为一个快捷方式)使用“尾随闭包”语法:
let arr = [1,2,3]
let arr2 = arr.map(){$0*2}
但是由于map
没有其他参数,你可以也省略括号 - Swift中唯一可以调用没有括号的函数的情况:
let arr = [1,2,3]
let arr2 = arr.map{$0*2}