我是Swift的新手,当我看书时,我发现Swift中的currying很复杂,我按照书中的说法编写代码,例如:
func curry<A, B, C>(f: (A, B) -> C) -> A -> B -> C {
return { x in { y in f(x, y) } }
}
func paraFunc(pa: Int, pb: Int) -> Int {
return pa - pb
}
var cab = curry(paraFunc)
cab(2)(3)
我不知道如何理解“ - &gt; A - &gt; B - &gt; C”。我知道泛型。但我对咖喱咖喱感到困惑,它是如何运作的?任何人都可以帮助我?
答案 0 :(得分:2)
- &GT;运算符是正确的关联。所以我们可以像这样重写咖喱功能。
func curry<A, B, C>(f: @escaping (A, B) -> C) -> ((A) -> ((B) -> C)) {
return { x in { y in f(x, y) } }
}
每个(
与返回部分内的{
匹配。
编辑:进一步解释
curry
函数采用非curried两个参数函数并使其成为curry。例如,我们有:
func sum(a: Int, b: Int) -> Int {
return a + b
}
现在我们可以像这样使用这个函数:
let result = sum(3, 6)
但是如果我们把它变成咖喱
let curriedSum = curry(sum)
现在我们可以像这样使用它:
let result = curriedSum(3)(6)
起初,这似乎是不必要和复杂的。但想想下一个表达的作用。
let sumWith3 = curriedSum(3)
这会生成一个新函数,它将Int
与它相加3.现在,我们在另一个函数中创建了一个新函数。现在我们可以像任何其他函数一样使用它。
Currying是函数式编程中的常见范例。事实上,在Haskell(另一种函数式编程语言)中,默认情况下每个函数都是curry。