zoukankan      html  css  js  c++  java
  • Clojure学习笔记(二)——函数式编程

    定义

    “函数式编程”是一种编程范式(programming paradigm),即如何编写程序的方法论。主要思想是把运算过程尽量写成一系列嵌套的函数调用。

    举例来说,现在有这样一个数学表达式:

      (1 + 2) * 3 - 4

    传统的过程式编程,可能这样写:

      var a = 1 + 2;

      var b = a * 3;

      var c = b - 4;

    函数式编程要求使用函数,我们可以把运算过程定义为不同的函数,然后写成下面这样:

      var result = subtract(multiply(add(1,2), 3), 4);

    特点

    1. 函数是“头等公民”(first class)

      指函数与其他数据类型一样,出于平等地位,可以赋值给其他变量,也可以作为参数,传入另一个函数,或者作为别的函数的返回值。

      举例来说,下面代码中的print变量就是一个函数,可以作为另一个函数的参数。

      var print = function(i){ console.log(i);};

      [1,2,3].forEach(print);

    2. 只用“表达式”,不用“statement”

      “表达式”是一个单纯运算的过程,总有返回值;“语句”是执行某种操作,没有返回值。函数式编程要求,只使用表达式,不使用语句。也就是说,每一步都是单纯的运算,而且都有返回值。

      原因是函数式编程的开发动机,一开始就是为了处理运算(computation),不考虑系统的读写(I/O)。"语句"属于对系统的读写操作,所以就被排斥在外。

    3. 没有“副作用”(side effect)

      "副作用",指函数内部与外部互动(如修改全局变量的值),产生运算以外的其他结果

      函数式编程强调没有"副作用",意味着函数要保持独立,所有功能就是返回一个新的值,没有其他行为,尤其是不得修改外部变量的值。

    4. 不可变状态

      函数式编程只是返回新的值,不修改系统变量。因此,不修改变量,也是它的一个重要特点。

      在其他类型的语言中,变量往往用来保存“状态”。不修改变量,意味着状态不能保存在遍历中。函数式编程使用参数保存状态

  • 相关阅读:
    WPF Caliburn 学习笔记(五)HelloCaliburn
    MSDN 教程短片 WPF 20(绑定3ObjectDataProvider)
    MSDN 教程短片 WPF 23(3D动画)
    比赛总结一
    HDU3686 Traffic Real Time Query System
    HDU3954 Level up
    EOJ382 Match Maker
    UESTC1565 Smart Typist
    HDU3578 Greedy Tino
    ZOJ1975 The Sierpinski Fractal
  • 原文地址:https://www.cnblogs.com/fengzhiwu/p/5613381.html
Copyright © 2011-2022 走看看