您现在的位置是:首页 >学无止境 >scala函数式编程网站首页学无止境
scala函数式编程
函数式编程
-
定义函数
def 函数名(参数:类型[,参数:类型]):返回类型={函数体} -
函数的类型 & 值
类型:(参数类型)=>返回类型
函数值 (参数)=>{函数体}
eg.
def counter(vlaue:Int):Int={value+=1}
函数类型 (Int)=>Int
函数值 (value)=>{value+=1} -
定义函数字面量
val counter:(Int)=>Int = {(value)=>{value+=1}} -
匿名函数(Lambda 表达式)
(参数)=>表达式
(num:Int)=> num*2
-
_的妙用
用来表示一个参数的一次使用,,不能用两次
多个参数可以用多个
-
高阶函数
- 实现:
2 + 3 + 4 + 5 2+3+4+5 2+3+4+5
2 2 + 3 2 + 4 2 + 5 2 2^2+3^2+4^2+5^2 22+32+42+52
2 2 + 2 3 + 2 4 + 2 5 2^2+2^3+2^4+2^5 22+23+24+25
- 普通实现:
sumInts,sumSquares,sumPowerOfTwo 都有一样的参数,相似结构的函数体
进一步提炼, - 生成高阶函数:
f :函数变量
等效上面 sumInts,sumSquares,sumPowerOfTwo
- 实现:
-
容器遍历 foreach
中缀表示法 & 匿名函数 & 高阶函数
等效
case(k,v) unapply+(k,v)是元组不用换指定对象 -
容器映射 map&flatMap
map 一对一映射
flatMap一对多
-
容器过滤 filter
-
规约
- reduce 左右规约
默认从左到右
- fold 同分左右,注意默认值给a还是b
- reduce 左右规约