当参数隐式时,为什么Swift闭包语法不接受使用return?

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

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...