/** * 集合类常用高级函数 * 高阶函数两个特点: * 函数接收函数作为参数 * 函数返回函数作为返回值 * map * flatmap * reduce * reduceleft * foreach * reducebykey * groupbykey */ var list1 = List(1,2,3,4) var list2 = 0::list1 // 合并到集合中 //list1.head // 第一个元素 1 //list1.tail // 第一个元素之后的其余元素 2,3,4 //print(list2) var list3 = scala.collection.mutable.LinkedList(1,2,3,4,5,6) //println(list3.elem) // 1 //println(list3.next) // LinkedList(2, 3, 4, 5, 6) val list = scala.collection.mutable.LinkedList(1, 2, 3, 4, 5) var list4 = list.map(_*2) //var list5 = list.map("the num is: " + _) //println(list5) //println(list4) /*for(i<- 0 until list.length) { print(list(i)) }*/ //var list5 = List("hello world","you name is").map(_.toUpperCase()) // flatmap是map的一个扩展,在flatmap函数体里,会传入一个函数,该函数对每个输入都返回一个集合,然后flatmap会把所有的集合都拍扁形成一个集合,如下例子: var list5 = List("hello world","you name is").flatMap(_.split(" ")) // List(hello, world, you, name, is) println(list5) // set // 0 定义 var s = Set(1,2,3) // 定义初始化的set 非可变 乱序 不可重复 // 1 添加元素 //var s1 = s+1 // 使用此方法添加元素 //println(s1) var s1 = scala.collection.mutable.HashSet[Int]() // 定义空set 使用链表方式维护插入顺序 s1 += 4 // 使用 += 添加元素 s1 += 5 //println(s1) // Set(5, 4) var s2 = scala.collection.mutable.SortedSet[String]() s2 += "hello" s2 += "tello" //println(s2) // TreeSet(hello, tello) var list7 = List("zm","liangliang").zip(List(32,31)) // 合并两个有序集合成为一个键值对集合 使用拉链操作 zip println(list7) // List((zm,32), (liangliang,31)) //val lines01 = scala.io.Source.fromFile("C://Users//Administrator//Desktop//test01.txt").mkString // val lines02 = scala.io.Source.fromFile("C://Users//Administrator//Desktop//test02.txt").mkString //var lines = List(lines01,lines02) var lines = List("hello world you ","hello world me ") // 统计文件中单词的总个数 不是单词计数 是所有单词总个数 // 把每个单词映射成 单词,1 这种元组形式, 然后针对每个tuple 映射出右侧的那个1 出,然后针对这些个1进行累加 // (hello,1) (world,1) (you,1) (hello,1) (world,1) (me,1) var result = lines.flatMap(_.split(" ")).map((_, 1)).map(_._2).reduceLeft(_ + _) // (1+1)+1 + 1 + 1 + 1 //lines.flatMap(_.split(" ")).map((_,1)).map(_._2).reduceLeft((_+_)) println(result) // 结果是 6 个单词 var firstTuple = ("str", 1 , 0.5) // 定义元组 //println(firstTuple._1) // 获取元组指定位置的值 结果为 str
原文地址:https://www.cnblogs.com/chengjianxiaoxue/p/11128934.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。