开始一直不理解闭包中的curry有什么用处, 最近刚好用到, 才算搞明白.
对于一个闭包定义:
如果要在一个调用中使用闭包
如果我要将一个带有参数的闭包作为另一个方法的参数, 按我本来的想法, 会这样做:
如果这样调用, 那么会先将myClosure(myParam)闭包执行, 然后将执行结果作为invokeClosure()方法的参数, 所以没法得到我期望的结果, 这是就应该使用curry了:
对于一个闭包定义:
def myClosure = {def param -> println param}如果要在一个调用中使用闭包
def invokeClosure(def myClosure){
...
myClosure();
...
}如果我要将一个带有参数的闭包作为另一个方法的参数, 按我本来的想法, 会这样做:
invokeClosure(myClosure("haha"));如果这样调用, 那么会先将myClosure(myParam)闭包执行, 然后将执行结果作为invokeClosure()方法的参数, 所以没法得到我期望的结果, 这是就应该使用curry了:
invokeClosure(myClosure.curry("haha"));
本文探讨了闭包中curry的应用场景。作者通过具体的代码示例解释了如何使用curry来传递参数给闭包,并确保闭包能在适当的时候被正确调用。
1497

被折叠的 条评论
为什么被折叠?



