-
它总是为相同的参数产生相同的输出。例如,无论如何,3+7 永远是 10。
-
它不会更改或修改输入变量。
第二个属性也称为不变性。纯函数的唯一结果是它返回的值。它们是确定性的。使用函数式编程完成的程序很容易调试,因为纯函数没有副作用或隐藏的 I/O。纯函数还可以更轻松地编写并行/并发应用程序。当代码以这种风格编写时,智能编译器可以做很多事情——它可以并行化指令,在需要时等待评估结果,并记住结果,因为只要输入不改变,结果就永远不会改变。
例子:
演示纯函数的 Python 程序
一个不改变输入列表并返回新列表的纯函数
def pure_func(List):
New_List = []
for i in List:
New_List.append(i**2)
return New_List
驱动程序代码
Original_List = [1, 2, 3, 4]
Modified_List = pure_func(Original_List)
print(“Original List:”, Original_List)
print(“Modified List:”, Modified_List)
输出:
Original List: [1, 2, 3, 4]
Modified List: [1, 4, 9, 16]
递归
在函数式编程中,没有 for 循环或 while 循环的概念,而是使用递归。递归是一个函数直接或间接调用自身的过程。在递归程序中,提供了基本情况的解决方案,而较大问题的解决方案则用较小的问题来表示。可能会出现一个问题,什么是基本情况?基本情况可以被认为是告诉编译器或解释器退出函数的条件。
示例:让我们考虑一个程序,该程序将在不使用任何 for 循环的情况下找到列表中所有元素的总和。
演示递归的 Python 程序
递归函数查找列表的总和
def Sum(L, i, n, count):
Base case
if n <= i:
return count
count += L[i]
进入递归
count = Sum(L, i + 1, n, count)
return count
驱动程序代码
L = [1, 2, 3, 4, 5]
count = 0
n = len(L)
print(Sum(L, 0, n, count))
输出:
15
函数是一等的,可以是高阶的
一等的对象自始至终统一处理。它们可以存储在数据结构中,作为参数传递,或者在控制结构中使用。如果一种编程语言将函数视为一等对象,则称其支持一等函数。
一等函数的性质:
-
函数是 Object 类型的实例。
-
你可以将函数存储在变量中。
-
你可以将函数作为参数传递给另一个函数。
-
你可以从函数返回函数。