就以上几点,我编了一首打油诗:java
函数编程很强大 一等公民都是它 外部变量不依赖 返回确保串行化
串行化什么意思呢?
一样计算(1+2)*3/4
,java代码以下:程序员
int a = 1 + 2 int b = a * 3 int c = b / 4
而Scala写出来以下:编程
val r = subtract(multiply(add(1, 2), 3), 4)
如此,就能够很简单的改写为:设计模式
val r = add(1, 2).multiply(3).subtract(4)
其中的美妙本身体会吧~~~安全
有机会看到这篇文章的读者,大概都会知道阿兰·图灵(Alan Turing)和约翰·冯·诺伊曼(John von Neumann)。阿兰·图灵提出了图灵机的概念,约翰·冯·诺伊曼基于这一理论,设计出了第一台现代计算机。多线程
因为图灵以及冯·诺伊曼式计算机的大获成功,历史差点淹没了另一位一样杰出的科学家和他的理论,那就是阿隆佐·邱奇(Alonzo Church)和他的λ演算。闭包
阿隆佐·邱奇是阿兰·图灵的老师,上世纪三十年代,他们一块儿在普林斯顿研究可计算性问题,为了回答这一问题,阿隆佐·邱奇提出了λ演算,其后不久,阿兰·图灵提出了图灵机的概念,尽管形式不一样,但后来证实,两个理论在功能上是等价的,条条大路通罗马。并发
若是不是约翰·麦卡锡(John McCarthy),阿隆佐·邱奇的λ演算恐怕还要在历史的故纸堆中再多躺几十年,约翰·麦卡锡是人工智能科学的奠定人之一,他发现了λ演算的珍贵价值,发明了基于λ演算的函数式编程语言:Lisp,因为其强大的表达能力,一推出就受到学术界的热烈欢迎,以致于一段时间内,Lisp 成了人工智能领域的标准编程语言。编程语言
很快,λ演算在学术界流行开来,出现了不少函数式编程语言:Scheme 、SML、Ocaml 等,可是在工业界,仍是命令式编程语言的天下,Fortran、C、C++、Java 等。函数式编程
随着时间的流逝,愈来愈多的计算机从业人员认识到函数式编程的意义,爱立信公司于上世纪八十年代开发出了 Erlang 语言来解决并发编程的问题;
在互联网的发展浪潮中,愈来愈多的语言也开始支持函数式编程:JavaScript、Python、Ruby、Haskell、Scala 等。
能够预见,若是过去找一个懂什么是函数式编程的程序员很困难,那么在不久的未来,找一个一点也没听过函数式编程的程序员将更加困难。
对于面向对象,咱们已经再熟悉不过了,因此这里不作过多介绍,直接分析它的优缺点.
面向对象程序设计能够看做一种在程序中包含各类独立而又互相调用的对象的思想(抽象现实世界),这与传统的思想恰好相反。
传统的程序设计主张将程序看做一系列函数的集合,或者直接就是一系列对电脑下达的指令。
面向对象程序设计中的每个对象都应该可以接受数据、处理数据并将数据传达给其它对象,所以它们均可以被看做一个小型的“机器”,即对象。
目前已经被证明的是,面向对象程序设计推广了程序的灵活性和可维护性,而且在大型项目设计中广为应用。
此外,支持者声称面向对象程序设计要比以往的作法更加==便于学习==(因此易于推广),由于它可以让人们更简单地设计并维护程序,使得程序更加便于分析、设计、理解。
同时它也是易拓展的,因为继承、封装、多态的特性,天然设计出高内聚、低耦合的系统结构,使得系统更灵活、更容易扩展,并且成本较低。
在面向对象编程的基础上发展出来的23种设计模式普遍应用于现今的软件工程中,极大方便了代码的书写与维护。
下面咱们在看看函数式编程(FP)
狭义地说,函数式编程没有可变的变量、循环等这些命令式编程方式中的元素,像数学里的函数同样,对于给定的输入,无论你调用该函数多少次,永远返回一样的结果。而在咱们经常使用的命令式编程方式中,变量用来描述事物的状态,整个程序,不过是根据不断变化的条件来维护这些变量。
广义地说,函数式编程重点在函数,函数是这个世界里的==一等公民==,函数和其余值同样,能够处处被定义,能够做为参数传入另外一个函数,也能够做为函数的返回值,返回给调用者。利用这些特性,能够灵活组合已有函数造成新的函数,能够在更高层次上对问题进行抽象。本文的重点将放在这一部分。
函数式编程和面向对象编程各有利弊,一个语法更加自由(FP),一个健壮性更好(OOP)。做为程序员应该对两种编程方式都有所了解,无论是哪一种方式,只要可以很好的解决当前的问题就是正确的方式,毕竟对于软件工程来讲解决问题是最主要的,用的工具反而没有那么重要,就像对程序员来讲语言不重要,重要的是解决问题的思想。
如今这二者的发展趋势是相互借鉴的,许多以面向对象做为基础的语言例如Java等都在新的版本中添加了对函数式编程的支持,而函数式编程则借鉴了一些在面向对象语言里用的一些编译技巧使得程序运行更快。
约翰·巴克斯(John Backus)为人熟知的两项成就是 FORTRAN 语言和用于描述形式系统的巴克斯范式,由于这两项成就,他得到了 1977 年的图灵奖。
有趣的是他在获奖后,作了一个关于函数式编程的讲演:Can Programming Be Liberated From the von Neumann Style? 1977 Turing Award Lecture。他认为像 FORTRAN 这样的命令式语言不够高级,应该有新的,更高级的语言能够摆脱冯诺依曼模型的限制,因而他又发明了 FP 语言,虽然这个语言未获成功,可是约翰·巴克斯关于函数式编程的论述却获得了愈来愈多的承认。下面,咱们就罗列一些函数式编程的优势。
首先,函数式编程自然有并发的优点。因为工艺限制,摩尔定律已经失效,芯片厂商只能采起多核策略。程序要利用多核运算,必须采起并发,而并发最头疼的问题就是共享数据,狭义的函数式编程没有可变的变量,数据只读不写,并发的问题迎刃而解。这也是前面两篇文章中,一直建议你们在定义变量时,使用 val 而不是 var 的缘由。爱立信公司发明的 Erlang 语言就是为解决并发的问题而生,在电信行业取得了不俗的成绩。
其次,函数式编程有迹可寻。因为不依赖外部变量,给定输入函数的返回结果永远不变,对于复杂的程序,咱们能够用值替换的方式(substitution model)化繁为简,轻松得出一段程序的计算结果。为这样的程序写单元测试也很方便,由于不用担忧环境的影响。
最后,函数式编程高屋建瓴。写程序最重要的就是抽象,不一样风格的编程语言为咱们提供了不一样的抽象层次,抽象层次越高,表达问题越简洁,越优雅。读者从下面的例子中能够看到,使用函数式编程,有一种高屋建瓴的感受。