(1)过滤
(2)转化/映射
(3)扁平化
(4)扁平化+映射 注:flatMap相当于先进行map操作,在进行flatten操作
(5)分组
(6)简化(规约)
(7)折叠
object TestList { def main(args: Array[String]): Unit = { val list: List[Int] = List(1, 2, 3, 4, 5, 6, 7, 8, 9) val nestedList: List[List[Int]] = List(List(1, 2, 3), List(4, 5, 6), List(7, 8, 9)) val wordList: List[String] = List("hello world", "hello atguigu", "hello scala") //(1)过滤 println(list.filter(x => x % 2 == 0)) //(2)转化/映射 println(list.map(x => x + 1)) //(3)扁平化 println(nestedList.flatten) //(4)扁平化+映射 注:flatMap相当于先进行map操作,在进行flatten操作 println(wordList.flatMap(x => x.split(" "))) //(5)分组 println(list.groupBy(x => x % 2)) } }
疑惑:
filter函数:返回一个List,其参数是一个返回Boolean类型的函数,如果返回值为true,则该元素返回。如果我们想保留list中的偶数,可以使用如下方法:
x => x % 2 == 0:匿名函数:
格式:
(x:Int)=>{函数体} x:表示输入参数类型;Int:表示输入参数类型;函数体:表示具体代码逻辑
案例实操:传递的函数有一个参数
传递匿名函数至简原则: (1)参数的类型可以省略,会根据形参进行自动的推导 (2)类型省略之后,发现只有一个参数,则圆括号可以省略;其他情况:没有参数和参数超过1的永远不能省略圆括号。 (3)匿名函数如果只有一行,则大括号也可以省略 (4)如果参数只出现一次,则参数省略且后面参数可以用_代替
// (1)定义一个函数:参数包含数据和逻辑函数 def operation(arr: Array[Int], op: Int => Int) = { for (elem <- arr) yield op(elem) } // (2)定义逻辑函数 def op(ele: Int): Int = { ele + 1 } // (3)标准函数调用 val arr = operation(Array(1, 2, 3, 4), op) println(arr.mkString(",")) // (4)采用匿名函数 val arr1 = operation(Array(1, 2, 3, 4), (ele: Int) => { ele + 1 }) println(arr1.mkString(",")) // (4.1)参数的类型可以省略,会根据形参进行自动的推导; val arr2 = operation(Array(1, 2, 3, 4), (ele) => { ele + 1 }) println(arr2.mkString(",")) // (4.2)类型省略之后,发现只有一个参数,则圆括号可以省略;其他情况:没有参数和参数超过1的永远不能省略圆括号。 val arr3 = operation(Array(1, 2, 3, 4), ele => { ele + 1 }) println(arr3.mkString(",")) // (4.3) 匿名函数如果只有一行,则大括号也可以省略 val arr4 = operation(Array(1, 2, 3, 4), ele => ele + 1) println(arr4.mkString(",")) //(4.4)如果参数只出现一次,则参数省略且后面参数可以用_代替 val arr5 = operation(Array(1, 2, 3, 4), _ + 1) println(arr5.mkString(","))