定义:高阶函数(带有函数参数的函数):把一个函数作为另一个函数的参数值
高阶函数示例
(*)map:相当于一个循环,对某个集合中的每个元素进行操作(就是接受一个函数),返回一个新的集合
val numbers = List(1,2,3,4,5,6,7,8,9,10)
numbers.map((i:Int)=>i*2)
简写 numbers.map(_ * 2)
(*)foreach:相当于一个循环,对某个集合中的每个元素进行操作(就是接受一个函数),不返回结果
numbers.foreach((i:Int)=>i*2)
(*)filter: 过滤,选择满足条件的数据
查询能够被2整除的数字
numbers.filter((i:Int)=> i%2==0) 如果是true,就返回结果
(*)zip: 合并集合
List(1,2,3).zip(List(4,5,6))
(*)partition: 根据断言(就是条件,通过一个匿名函数来实现)的结果,来进行分区
举例:把能够被2整除的分成一个区,不能整除的分成另一个区
numbers.partition((i:Int)=> i%2==0)
(*)find: 查找第一个满足条件(断言)的元素
查询第一个能够被3整除的数字
numbers.find(_%3 == 0)
(*)flatten:把嵌套的结构展开
List(List(2, 4, 6, 8, 10),List(1, 3, 5, 7, 9)).flatten
(*)flatMap 相当于 map + flatten
var myList = List(List(2, 4, 6, 8, 10),List(1, 3, 5, 7, 9))
myList.flatMap(x=> x.map(_*2))
结果 res16: List[Int] = List(4, 8, 12, 16, 20, 2, 6, 10, 14, 18)
过程: (1)将List(2, 4, 6, 8, 10)和List(1, 3, 5, 7, 9)调用x=> x.map(_*2)
(2)再合并成一个List