近些年在大数据分布式计算的急速发展下,催生出各种大型软件的工业需求。而这种大型软件要容易理解和维护,OOP繁琐的语法及指令式编程肯定是力不从心的。于是人们就把视野重新回归到了没有副作用的编程范式----FP函数式。
函数式编程强调函数组合,把一个函数的输出当做另一个函数的输入组合成一个更大的函数。我们可以直接面对最基本的组件编程,组合过程是明确可料的(函数引用透明),把细微的功能组合成大型软件,而且还能避免重复代码。增加了可读性和可维护性。
特性:
1.闭包和高阶函数
闭包:依照函数文本运行时创建的函数值(对象)
实质上,闭包是起函数的作用并可以像对象一样操作的对象。
高阶函数可以用另一个函数(间接地,用一个表达式) 作为其输入参数,在某些情况下,它甚至返回一个函数作为其输出参数。这两种结构结合在一起使得可以用优雅的方式进行模块化编程,这是使用 FP 的最大好处。
2.惰性计算(求值)
表达式不是在绑定到变量时立即计算,而是在求值程序需要产生表达式的值时进行计算。
3.函数是第一等公民
4.引用透明
任何程序中符合引用透明的的表达式都可以由它的的结果所替代,而不改变该程序的含义。
5.没有副作用
一个函数在程序的执行过程中除了根据输入参数给出的运算结果之外没有其他的影响,就可以说是没有副作用的
6.只用‘表达式’,不用‘语句’
告诉计算做什么,而不是告诉它怎么做。
7.状态不可变
好处:
1. 代码简洁,开发快速
2. 接近自然语言,易于理解
3. 更方便的代码管理
4. 易于"并发编程"
5. 代码的热升级