Swift的语言设计背后的原因是什么使得以下内容可以接受
[1,2,3,4].map({ (number:Int)->Int in return number * 3 }) // ok
要么
[1,4].map({ number in number * 3 }) // ok
要么
[1,4].map({ 3 * $0 }) // ok
虽然这是不可接受的?
[1,4].map({ return 3 * $0 }) // not ok
解决方法
这显然是编译器错误,因为将闭包移动到它工作的单独变量:
let closure1: (Int) -> (Int) = { return 3 * $0 } var closure2: (Int) -> (Int) = { return 3 * $0 } [1,4].map( closure1 ) // Works [1,4].map( closure2 ) // Works [1,4].map( { return 3 * $0 } ) // Fails
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。