函数式编程思想

对于函数式编程来讲,其只关心,定义输入数据和输出数据相关的关系,数学表达式里面实际上是在作一种映射(mapping),输入的数据和输出的数据关系是什么样的,是用函数来定义的。html

左耳朵耗子:什么是函数式编程

http://www.yxtvg.com/toutiao/5413179/20180212a04ro500.html。程序员

 

函数式编程思想:先构造计算树,而后执行计算树。编程

 

函数式编程的开发过程是编写计算实现、调用约定、和计算结构的过程;promise

执行的过程是履行计算约定的过程。app

与面相对象作比较:编程语言

面向对象是结构的构建,要素是对象与关系;函数式编程

函数式编程是计算的构建,要素是函数和在听从调用约定的树上行走的信息流。函数

 

函数式结构树的构建过程和执行过程都听从信息流约定。lua

调用的时机和顺序都有信息流约定来规范。spa

 

函数式结构树的构建过程只是计算的绑定的过程;从执行的角度看它有另外一个术语“惰性求值”:

函数式编程语言还提供惰性求值(Lazy evaluation,也称做call-by-need),是在将表达式赋值给变量(或称做绑定)时并不计算表达式的值,而在变量第一次被使用时才进行计算。

某些编程语言缺省延迟表达式的求值,另外一些提供函数或特殊语法来延迟求值。在 Miranda 和 Haskell 中,缺省延迟函数实际参数的求值。在不少其余语言中,可使用特殊语法明确悬置计算来延迟求值(好比 Scheme 的 "delay" 或 "force"),更通常的经过把一个表达式包装在 thunk 中。表示这种明确延迟求值的对象叫作预期或承诺。

The benefits of lazy evaluation include:

  • The ability to define control flow (structures) as abstractions instead of primitives.

 

结构树的生成与执行:

调用约定、参量约定、信息流约定、promise;

信息流对参量逐步赋值的 过程。

生成的过程是将计算进行保存,而不是使用计算求值的过程。

 

函数式编程须要一些基础设施进行支撑。

根和干的部分由基础设置完成;

枝干和叶子节点由程序员完成。

函数式编程的运行环境都会提供最基本的运算。

 

数据和事件在这个结构树上只至关于信号。

 

统领全局的是输入、输出及处理流程的逻辑,是信息处理的流程。

要关注输出在哪里;一般来讲,程序员所作的部分只是整个信息处理系统的一部分。

 

函数式编程与信息处理系统有不少相似的地方;

都是输入信号,而后通过一系列的子系统的处理,最后拿到指望的结果。

 

它的使用场景也有上面的相似性决定:即处理信息和信号流。

 

开发的过程即为为这个信号处理系统添加子系统。

 

不同的地方在于信号处理系统是单向的;而函数式编程须要使用栈的结构来返回递归和嵌套处理过的值,也包含最终的值。

相关文章
相关标签/搜索