函数式编程和高阶函数

函数式编程

函数式编程就是一种抽象程度很高的编程范式,纯粹的函数式编程语言编写的函数没有变量,因此,任意一个函数,只要输入是确定的,输出就是确定的,这种纯函数我们称之为没有副作用。而允许使用变量的程序设计语言,由于函数内部的变量状态不确定,同样的输入,可能得到不同的输出,因此,这种函数是有副作用的。

函数式编程的一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数!

Python对函数式编程提供部分支持。由于Python允许使用变量,因此,Python不是纯函数式编程语言。

一、定义

比如有一个数学运算:

(1+2)*3-4

 如果要用程序实现上面的运算可能会是这样:

var a = 1+2
var b = a*3
var c = b-4

 函数式编程要求使用函数,把不同的运算定义成不同的函数,然后写成以下方式:

var result = subtract(mutiply(add(1,2),3),4)

 这个就是一个简单的函数式编程。

高阶函数

变量可以指向函数,函数的参数可以接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数称为高阶函数。

简单的理解就是函数的参数可以是另外一个函数本身。

def add(a,b,f):
    return f(a)+f(b)

print(add(1,2,abs))#3
print(add(1,-2,abs))#3

 

posted on 2017-07-24 10:28  老榕树下的咖啡屋  阅读(162)  评论(0编辑  收藏  举报