您的位置:首页 > 其它

scala学习笔记

2017-01-02 21:05 169 查看

函数式编程的特点

函数是一等公民
即first class,函数与其他数据类型一样,处于平等地位,可以赋值给其他变量;作为参数传入函数中;作为函数返回值。

只用表达式,不用语句
表达式expression是一个有返回值的运算过程,而语句statement是执行操作,没有返回值。函数式编程要求,只使用表达式,而不用语句,即运算且要有返回值。
语句属于系统的读写I/O操作(没有懂?),而在实际应用中,不可能没有I/O操作,因此不要有不必要的读写操作,进而保持计算过程的单纯性。

没有副作用
Side effect,函数内部与外部互动(如:修改全局变量的值),产生运算以外的其他结果。函数式编程强调没有副作用,即函数要保持独立,所有功能就是返回一个值,没有其他行为,尤其是不得修改外部变量的值。

不修改状态
函数式编程只返回值,不修改系统变量,即状态不能保存在变量中。函数式编程使用参数保存状态,如递归,由于使用了递归,函数式语言的运行速度较慢,也是长期不能在业界推广的主要原因。

引用透明
Referential transparency,函数的运行不依赖于外部变量或状态,只依赖于输入的参数,任何时候只要参数相同,引用函数所得到的返回值就总是相同的。

其他类型的语言:函数的返回值可能与系统状态有关,在不同状态下,返回值可能不一样。这叫“引用不透明”,不利于观察和理解程序的行为。

函数式编程的价值

代码简洁,开发快速
使用函数,减少重复代码,程序较短,开发速度较快。

接近自然语言,易于理解
自由度高,可以写出很接近自然语言的代码。如:

// 以下所有函数均需要自己实现
// (1+2)*3-4
subtract(multiply(add(1,2),3),4)
add(1,2).multiply(3).subtract(4)
// 易懂的代码示例
merge([1,2],[3,4]).sort().search("2")


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

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

// s1和s2互不干扰,不会修改变量,无所谓执行顺序,可以分配到两个线程上完成
var s1 = Op1()
var s2 = Op2()
var s3 = concat(s1, s2)


代码热升级
只要保证接口不变,内部实现就与外部无关,所以,可以在运行状态下直接升级代码,不需要重启,也不需要停机。

基础语法

函数定义

// 函数定义
def 函数名(变量名:变量类型):函数返回值类型={函数体}
// 当函数是递归的,那么必须明确说明函数返回值类型;在非递归函数中,编辑器可以推断函数返回值类型。
// 默认的函数返回值类型为Unit,Unit指的是函数没有有效的返回值,类似于Java的void。因此结果类型是Unit的方法,并非为了得到返回值,而是为了其他的运行效果。

值函数与匿名函数

闭包

闭包=代码+用到的非局部变量
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: