【问题标题】:Why swift 3 requiring `_` in closure parameter? [duplicate]为什么 swift 3 在闭包参数中需要`_`? [复制]
【发布时间】:2016-12-24 06:36:38
【问题描述】:

我是 swift 3 的新手。我有现有代码并想将其转换为 swift 3。我只是好奇为什么 xcode 要求我在参数名称前插入 _

func anotherClosure(age: Int, name: String, handler: (_ name: String, _ age: Int) -> ()) {
        handler(name, age)
    }

我在网上搜索,但找不到答案。如果您有更好的方法来创建具有多个值的闭包以传递给处理程序,请在下面发表评论。

谢谢

【问题讨论】:

标签: xcode swift3


【解决方案1】:

在 Swift 3 之前,参数名称是类型的一部分,就类型系统而言。但是,强制正确匹配关键字名称会使使用闭包成为一场噩梦。因此,类型系统忽略了它们,这就引出了一个问题,为什么它们是名字中类型的一部分。

import CoreFoundation

func applyAndPrint(closure: (a: Double, b: Double) -> Double, _ a: Double, _ b: Double) {
    print(a, b, closure(a: a, b: b))
}

//All these have different types, because of their different keyword parameter names.
let adder: (augend: Double, addend: Double) -> Double = { $0 + $1 }
let subtractor: (minuend: Double, subtrahend: Double) -> Double = { $0 - $1 }
let multiplier: (multiplicand: Double, multiplier: Double) -> Double = { $0 * $1 }
let divider: (dividend: Double, divisor: Double) -> Double = { $0 / $1 }
let exponentiator: (base: Double, exponent: Double) -> Double = { pow($0, $1) }
let rooter: (degree: Double, Radicand: Double) -> Double = { pow($1, 1/$0) }

// Yet the type system ignores that, and all these are valid:
applyAndPrint(adder, 2, 3)
applyAndPrint(subtractor, 2, 3)
applyAndPrint(multiplier, 2, 3)
applyAndPrint(divider, 2, 3)
applyAndPrint(exponentiator, 2, 3)
applyAndPrint(rooter, 2, 3)

【讨论】:

    猜你喜欢
    • 2013-09-05
    • 2019-12-03
    • 1970-01-01
    • 2012-08-07
    • 1970-01-01
    • 2012-09-15
    • 2018-05-04
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多