我有一堆函数,如果没有提供,我希望能够指定默认闭包。如果没有一些丑陋的代码,我似乎无法弄清楚如何做到这一点。

例如,我希望 perform 函数接受一个名为 closure 的可选参数,该参数在提供时执行。否则它将默认执行 myClosure 。我怎样才能做得更好,这样我就不必重复函数调用了?

class MyClas {

    typealias closureType = ((number: Int) -> Int)?

    func myClosure (number: Int) -> Int {
        return number * 2
    }

    func perform(number: Int, closure: closureType = nil) -> Int {
        if closure == nil {
            return myClosure(number)
        } else {
            return closure!(number: number)
        }

    }
}

理想情况下,我可以做到这一点!
class MyClass {

    typealias closureType = ((number: Int) -> Int)?

    func myClosure (number: Int) -> Int {
        return number * 2
    }

    func perform(number: Int, closure: closureType = myClosure) -> Int {
        return closure(number: number)

    }
}

最佳答案

你的问题是你已经使 myClosure 成为一个方法(或成员函数),这意味着它没有你想要的签名(它是一个柯里化的函数,类型为 MyClass->Int->Int )。

要么将其从类中拉出,要么使其成为静态(在类的情况下更确切地说是“类”)方法:

class MyClass {

    typealias closureType = (number: Int) -> Int

    class func myClosure (number: Int) -> Int {
        return number * 2
    }

    func perform(number: Int, closure: closureType = MyClass.myClosure) -> Int {
        return closure(number: number)

    }
}

附言一旦你这样做了,它就不再是可选的了

只是为了显示它作为非静态方法编译:
class MyClass {

    typealias closureType = MyClass -> (number: Int) -> Int

    func myClosure (number: Int) -> Int {
        return number * 2
    }

    func perform(number: Int, closure: closureType = myClosure) -> Int {
        return closure(self)(number: number)

    }
}

let c = MyClass()
println(c.perform(5))  // prints 10

关于ios - 如何使用默认值使闭包成为可选,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28508897/

10-10 21:03
查看更多