函数式编程语言

Posted kangrui201610411307

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了函数式编程语言相关的知识,希望对你有一定的参考价值。

 1、什么是函数式编程语言?

  函数式编程语言(functional programming language)或称函数程序设计,又称泛函编程,是一种编程典范,它将计算机运算视为数学上的函数计算,并且避免使用程序状态以及易变对象。函数编程语言最重要的基础是λ演算(lambda calculus)。

  函数式编程语言的特征:

  (1)以“函数”为首,如同命令式语言中的“变量”,函数可以赋值给其他变量,可以作为其他函数的参数,或者作为其他函数的返回值。

  (2)不修改变量的值

  (3)只有表达式,没有语句。此处的语句指的是没有返回值得某些操作。

  (4)引用透明(Referential transparency),函数的运行不依赖与外部变量或“状态”,简单的说就是,同一个输入(参数),总是会产生同一个输出(返回值),这与数学函数的特征很一致。命令式语言因为全局变量等的存在,就无法做到这一点。

  (5)对比命令式语言,递归形式的循环。

  2、函数式编程语言有哪些?

  纯函数式编程语言:

    强静态类型:Concurrent Clean、Haskkell、Miranda

    弱类型:Lazy K

  非纯函数式编程语言:

    强静态类型:F#、ML、OCaml、Scala

    强动态类型:Erlang、LISP、LOGOScheme、Clojure、Mathematica、R

    强弱型:Unlambda

  其他函数编程语言:

    APL、XSLT

  3、函数式编程语言为什么会流行?

  1. 代码简洁,开发快速。函数式编程大量使用函数,减少了代码的重复,因此程序比较短,开发速度较快。

  2. 接近自然语言,易于理解。函数式编程的自由度很高,可以写出很接近自然语言的代码。

  3. 更方便的代码管理。函数式编程不依赖、也不会改变外界的状态,只要给定输入参数,返回的结果必定相同。因此,每一个函数都可以被看做独立单元,很有利于进行单元测试(unit testing)和除错(debugging),以及模块化组合。

  4. 易于"并发编程"。函数式编程不需要考虑"死锁"(deadlock),因为它不修改变量,所以根本不存在"锁"线程的问题。不必担心一个线程的数据,被另一个线程修改,所以可以很放心地把工作分摊到多个线程,部署"并发编程"(concurrency)。

  5. 代码的热升级。函数式编程没有副作用,只要保证接口不变,内部实现是外部无关的。所以,可以在运行状态下直接升级代码,不需要重启,也不需要停机。

    6. 函数式语言具有并行、单元测试、没有额外作用、不修改状态、引用透明、代码部署热等特点 

以上是关于函数式编程语言的主要内容,如果未能解决你的问题,请参考以下文章

第36期函数式编程和响应式编程资料汇总

函数式编程

RxJS 与 函数式编程 - 函数式编程

函数式编程

函数式编程的核心思想

Scala 函数式编程 什么是函数式编程?