Swift的语言设计背后的原因是什么使得以下内容可以接受 [1, 2, 3, 4].map({ (number:Int)-Int in return number * 3 }) // ok 要么 [1, 2, 3, 4].map({ number in number * 3 }) // ok 要么 [1, 2, 3, 4].map({ 3 * $0 }) // ok 虽
[1, 2, 3, 4].map({ (number:Int)->Int in return number * 3 }) // ok
要么
[1, 2, 3, 4].map({ number in number * 3 }) // ok
要么
[1, 2, 3, 4].map({ 3 * $0 }) // ok
虽然这是不可接受的?
[1, 2, 3, 4].map({ return 3 * $0 }) // not ok这显然是编译器错误,因为将闭包移动到它工作的单独变量:
let closure1: (Int) -> (Int) = { return 3 * $0 } var closure2: (Int) -> (Int) = { return 3 * $0 } [1, 2, 3, 4].map( closure1 ) // Works [1, 2, 3, 4].map( closure2 ) // Works [1, 2, 3, 4].map( { return 3 * $0 } ) // Fails