函数式编程

142 阅读1分钟

前言

函数式编程是种编程方式,它将电脑运算视为函数的计算。函数编程语言最重要的基础是λ演算(lambda calculus),而且λ演算的函数可以接受函数当作输入(参数)和输出(返回值)。

常见的编程范式

函数式编程、面向过程编程、面向对象编程、指令式编程等

定义

函数式编程是一种编程范式(programming paradigm),也就是如何编写程序的方法论。 它属于"结构化编程"的一种,主要思想是把运算过程尽量写成一系列嵌套的函数调用。

  • 和指令式编程相比,函数式编程强调函数的计算比指令的执行重要。
  • 和过程化编程相比,函数式编程里函数的计算可随时调用。

纯函数的定义

* 相同输入必定能得出相同输出。 * 函数执行过程中没有任何副作用。

详情参见 函数式编程 -- 纯函数、柯里化

面向对象编程

把现实世界中的事物抽象成程序世界中的类和对象,通过封装、继承和多态来演示事物事件的联系。

函数式编程

把现实世界的事物和事物之间的联系抽象到程序世界(对运算过程进行抽象)。

函数式与非函数式

 let num1 = 2; 
 let num2 = 3;
 let sum = num1 + num2;
 console.log(sum); 
 
 // 函数式 
 function add (n1, n2) { 
     return n1 + n2;
 }
 let sum = add(2, 3); 
 console.log(sum);

总结

函数式编程是用来描述数据(函数)之间的映射,也可以说,==函数式编程其实就是对运算过程的抽象==。

参考 baike.baidu.com/item/%E5%87…