When should I write my functions in curried form?不符合我的想法,需要纠正自己。
作为我学习link的一部分,这就是我对函数curring的理解。下面是一个例子:
def curry2(f):
"""Returns a function g such that g(x)(y) == f(x, y)
>>> from operator import add
>>> add_three = curry2(add)(3)
>>> add_three(4)
"""
def g(x):
def h(y):
return f(x, y)
return h
return g
在任何应用程序中,如果我知道参数的数量是固定的(比如说2个参数),并且
函数名是normalise_range
(比方说),然后我将定义def normalise_range(x, y):
函数,并通过调用normalise_range(x, y)
在应用程序中直接使用它。
在任何应用程序中,如果我知道,参数的数量是固定的(比如说2个参数),
但是函数名是可变的(可以是normalise_range
/average
/我不知道..),
然后我将使用如上所示的def curry2(f):
,它将接受接受接受两个参数(固定)的所有函数。
我的问题是:
函数curring的目的是方便地从更一般的函数中获取专门的函数。您可以通过在不同的时间预先设置一些参数并在之后保持这些参数不变来实现这一目的。
这与命名无关。在Python中,您可以随时轻松地重命名变量/函数。
示例:
给予
现在还没有那么激动人心。它只将类型为
f(a,b,c)
的函数调用替换为类型为f(a)(b)(c)
的调用,这甚至可能被视为Python中不太优雅的风格。但它允许你做:
它给予
因此,curring的优点是,您可以获得具有固定参数的专用函数,并且可以使用这些函数,而不是编写更通用的表单并在每次调用时设置固定的参数。
咖喱的替代品是:
partial
,lambda
和default parameters
。因此,在实践中,咖喱可能是有用的,但你也可以绕过它,如果你想。另见Currying in Python
咖喱菜至少有两个优点:
1)它保留您的代码(依次是您的思考)DRY。
假设你有这样一个函数:
通过curring,您可以获得该
context
的一个专门的函数,该函数可以被丢弃等。您不必再次重复上下文。2)用单个输入函数来思考要比
n
参数容易得多;尽管有时这是有争议的。另请参见:What is the difference between currying and partial application?
相关问题 更多 >
编程相关推荐