- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
根据 Apple documentation ,闭包的语法如下
{ (parameters) -> return type in
statements
}
将参数和返回类型放在 curlies 中而不是使用更熟悉的函数类型语法(例如
)背后的逻辑推理是什么 func name(parameters) -> return_type {
statements
}
最佳答案
闭包语法是在一些常见情况下促进简洁的方式。考虑命名函数语法,如果它用于闭包(显然删除 name
因为闭包是匿名函数文字)。
而不是当前的方法(最冗长的形式):
let f: (Type) -> ReturnType = { (parameter: Type) -> ReturnType in
return process(parameter)
}
它会是:
let f: (Type) -> ReturnType = func (parameter: Type) -> ReturnType {
return process(parameter)
}
这有很多问题。首先,闭包通常可以推断出它们的参数和返回类型,因此语法为:
let f: (Type) -> ReturnType = func (parameter) {
return process(parameter)
}
这开始变得有点困惑了。这是返回 Void 的函数,还是返回 ReturnType 的函数?在标准的命名函数语法中,省略返回类型意味着 Void,但在这里它并不那么明显。编译器是肯定的;不会有歧义,但它已经以微妙的方式偏离了命名函数语法。
(让所有函数都包含它们的返回类型会更加一致,但我认为许多 Swift 开发人员会因为不得不如此频繁地键入 -> Void
而感到不安。或者他们可以所有函数都有隐式返回类型,就像在 Scala 中一样,但他们觉得这会损害可读性。)
现在考虑隐式参数和假设返回的情况:
let f: (Type) -> ReturnType = func { process($0)}
这是一个非常非常常见的案例。例如考虑它会对 map
做什么:
xs.map(func { process($0) })
我认为这里额外的 func
只是噪音。 xs.map{ process($0) }
是更好的 IMO。
一个更深层次的问题是为什么函数不遵循闭包语法。如果没有像这样的“方法”功能属性,实际上会有很多好处:
struct Foo {
let dothing = { (x: Int) -> Int in x * 2 }
}
而不是
struct Foo {
func dothing(x: Int) -> Int { return x * 2 }
}
命名函数如此特殊的事实实际上是 Swift 的奇怪之处,它带来了很多令人头疼的问题(比如你不能使用函数属性来符合协议(protocol),只能使用命名函数)。
但提供 func
语法对 C、Java 和 JavaScript 开发人员来说感觉更自然,这就是我怀疑它存在的原因。对于 ML 和 Scala 开发人员来说,这很奇怪。但它对于闭包的效果几乎没有那么好。
关于swift - Swift 中 Closure block 语法背后的逻辑推理是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34347275/
我刚刚开始使用 Google Closure 做一些工作,我想将选择字段的创建移动到它自己的模板中,并使用类似以下内容调用该模板: {call templates.utils.select} {p
我有一些代码,简化后看起来像: fn foo() -> Vec { unsafe { unsafe_iterator().map(|n| wrap_element(n)).co
我正在从脚本内部调用Closure Compiler(closurecompiler.jar)。该脚本还生成Closure Compiler需要编译的一些javascript。有没有办法将此JavaS
以下示例代码生成有关高级优化的编译器警告:“JSC_UNSAFE_NAMESPACE:为命名空间 NS 创建的别名不完整”。如果我删除@enum 注释,它不会发出警告。 var NS = {}; /*
看代码: let add_one = |&: x| { 1 + x }; 我知道x是闭包参数,但是闭包中的&:是什么意思? 最佳答案 这是 Rust 的一个文档不足的部分(并且过时,请参阅评论)。我知
PHP manual for anonymous functions (即闭包)指出: Anonymous functions are currently implemented using the
我从脚本内部调用 Closure Compiler (closurecompiler.jar)。该脚本还生成了一些 Closure Compiler 需要编译的 javascript。有没有办法将这个
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 7年前关闭。 Improve t
当鼠标在文档正文中移动时,我试图调用一个函数。但是,下面的事件处理程序不起作用。 goog.events.listen(document, 'onmousemove', function(e)
我试过了 java -jar compiler.jar --js jj.js --js_output_file jj.js 输出文件大小为 0。 如果我不想从 .min.js 重命名为 .js,我该怎
Google Closure UI库如何与Google DART一起使用? 最佳答案 Dart没有使用JavaScript库的功能。这是设计使然,因为Dart旨在同时针对Dart VM和转换为JS的D
是否可以使用 Google Closure 编译器在两个文件中定义一个类?例如,如果我自动生成一个类并希望为用户输入的代码保留另一个类: 在 MyClass.AutoGenerated.js 中 go
当我在 http://closure-compiler.appspot.com 处的闭包编译器中测试以下代码时: // ==ClosureCompiler== // @output_file_name
是否可以使用 Google Closure 编译器在两个文件中定义一个类?例如,如果我自动生成一个类并希望为用户输入的代码保留另一个类: 在 MyClass.AutoGenerated.js 中 go
当我运行闭包编译器时,会收到一堆这样的警告: [exec] jquery/3.2.1/dist/jquery.js:733: WARNING - Suspicious code. The resul
假设您正在一个具有多个外部库依赖项的 javascript 项目中工作,并且想要在 ADVANCED_OPTIMIZATIONS 模式下使用 Google Closure Compiler 编译您的源
我正在为 PIXI.js 库准备 externs。我收到以下警告: js/Test.js:188: WARNING - Property position never defined on PIXI.
我最近使用 Google 的 Closure 编译器创建了一个 JavaScript 库:https://github.com/bvaughn/task-runner 我打算让这个库供那些也需要完整闭
我正在尝试自学闭包模板。我做了一个简单的文件 simple.soy: {namespace examples.simple} /** * says hello to the world * @pa
我正在将一个项目从 jQuery 迁移到 Closure。我有一些我想编译的只迁移了一半的代码。未编译的源工作正常。我想知道使用 SIMPLE_OPTIMIZATIONS 编译它的编译命令。 原始基于
我是一名优秀的程序员,十分优秀!