18 高阶函数
在数据和计算中,高阶函数是至少满足下列一个条件的函数:
1)接受一个或多个函数作为输入
2)输出一个函数
输出一个函数
// 输出Int类型
scala> def add(a:Int, b:Int) = a + b
add: (a: Int, b: Int)Int
// 输出函数Int => Int
scala> def add(a:Int, b:Int) = (c:Int) => a + b + c
add: (a: Int, b: Int)Int => Int
// 使用时需要传入多个括号的数据
scala> add(1,2)
res0: Int => Int =
scala> res0(3)
res1: Int = 6
scala> add(1,2)(3)
res2: Int = 6
// 输出函数 Int => (Int => Int)
scala> def add(a:Int, b:Int) = (c:Int) => (d:Int) => a + b + c + d
add: (a: Int, b: Int)Int => (Int => Int)
scala> add(1,2)(3)(4)
res3: Int = 10
传入的是一个函数
传入函数 (Int,Int) => Int
// 输入参数是 函数 (Int,Int)=>Int
scala> def js(func:(Int,Int)=>Int) = func
js: (func: (Int, Int) => Int)(Int, Int) => Int
scala> val func1 = (a:Int, b:Int) => a + b
func1: (Int, Int) => Int =
scala> val func2 = (a:Int, b:Int) => a * b
func2: (Int, Int) => Int =
scala> js(func1)
res6: (Int, Int) => Int =
scala> res6(1,2)
res7: Int = 3
scala> js(func1)(1,2)
res8: Int = 3
scala> js(func2)(1,2)
res9: Int = 2
传入函数 Int => Int
scala> def js(func:(Int)=>Int) = func
js: (func: Int => Int)Int => Int
scala> val func1 = (a:Int) => a + 10
func1: Int => Int =
scala> val func2 = (a:Int) => a * 10
func2: Int => Int =
scala> js(func1)(1)
res10: Int = 11
scala> js(func2)(1)
res11: Int = 10
在上面的基础上,在集合里用函数
scala> val list = List(1,2,3,4,5)
list: List[Int] = List(1, 2, 3, 4, 5)
// 将列表中每个元素+1 产生新元素,并组成新列表
scala> list.map(f => js(func1)(f))
res13: List[Int] = List(11, 12, 13, 14, 15)
scala> list.map(js(func1)(_))
res14: List[Int] = List(11, 12, 13, 14, 15)
scala> list.map(js(func1))
res15: List[Int] = List(11, 12, 13, 14, 15)
scala> list.map(js(func2))
res16: List[Int] = List(10, 20, 30, 40, 50)
19 部分参数函数
如果函数传递所有预期的参数, 则表示已完全应用它。 如果只传递几个参数并不是全部参数, 那么将返回部分应用的函数。 这样就可以方便地绑定一些参数, 其余的参数可稍后填写补上;
scala> def add(a:Int, b:Int) = a + b
add: (a: Int, b: Int)Int
scala> add(1,2)
res17: Int = 3
// 部分参数就是 固定一部分参数,传入一部分参数
// 方式1:
// 使用时,用_:Int 做参数占位,用于传入参数
scala> val func1 = add(1, _:Int)
func1: Int => Int =
scala> func1(2)
res20: Int = 3
// 方式2
// 利用函数,固定一部分参数,传入一部分参数
scala> val func2 = (b:Int) => add(1, b)
func2: Int => Int =
scala> func2(2)
res21: Int = 3
海汼部落原创文章,原文链接:http://hainiubl.com/topics/75750