什么是函数式编程
为什么现在还要学函数式编程?
- 函数式编程是随着 React 的流行受到越来越多的关注
- Vue 3也开始拥抱函数式编程
- 函数式编程可以抛弃 this
- 打包过程中可以更好的利用 tree shaking 过滤无用代码
- 方便测试、方便并行处理
- 有很多库可以帮助我们进行函数式开发:lodash、underscore、ramda
函数式编程(Functional Programming, FP),FP 是编程范式之一,我们常听说的编程范式还有面向过程编程、面向对象编程
-
面向对象编程的思维方式:把现实世界中的事物抽象成程序世界中的类和对象,通过封装、继承和多态来演示事物事件的联系
-
函数式编程的思维方式:把现实世界的事物和事物之间的联系抽象到程序世界(对运算过程进行抽象)
个人理解: y= sin(x),sin(x) = y, x和y的关系(数学的关系,相同的输入始终要的到相同的输出)
// 非函数式
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)
纯函数的概念
纯函数: 相同的输入永远会得到相同的输出, 而且没有任何可观察的副作用
- 纯函数就类似数学中的函数(用来描述输入和输出之间的关系), y = f(x); 举例: 数组中的 slice 和 splice 分别是纯函数和不纯函数
- slice 返回数组中的指定部分, 不会改变原数组
- splice 对数组进行操作返回该数组,会改变原数组
好处: 可缓存 因为纯函数对相同的输入始终有相同的结果,所以可以把纯函数的结果缓存起来 可测试 纯函数让测试更方便 并行处理 在多线程环境下并行操作共享的内存数据很可能会意外情况 纯函数不需要访问共享的内存数据,所以在并行环境下可以任意运行纯函数(Web Worker) lodash 中有个记忆函数
函数的副作用
副作用让一个函数变的不纯,纯函数的根据相同的输入返回相同的输出,如果函数依赖于外部的状态就无法保证输出相同,就会带来副作用。
副作用来源:
- 配置文件
- 数据库
- 获取用户的输入
- ...... 所有的外部交互都有可能代理副作用,副作用也使得方法能用性下降不适合扩展和可重用性,同时副作用会给程序中带来安全隐患 给程序带来不确定性,但是副作用不可能完全禁止,尽可能控制它们在可控范围内发生。