scala中的陣列和集合操作
阿新 • • 發佈:2019-02-19
package kang /* 1.在scala集合中,Iterable是共同的Trait,Iterable要求繼承者實現一些共同的方法,例如元素的遍歷 * 2。Array是scala基礎的資料結構,不從屬於scala集合體系 * 3.scala集合分為可變和不可變集合。,不可變集合在scala.collection.immutable裡,可變在scala.collection.mutable * * 4.List集合是不可變的,head指第一個元素,tail指剩下的元素組成的集合,而LinkedList可變 * 5.使用雙冒號::將list集合和其他元素組成新的集合 * 6.當集合中沒有元素時,返回Nil * 7.Set是不可重複的集合 * */ object Sacla_Iterable { def main(args: Array[String]): Unit = { val range = 1 to 10 val list = List(1,2,3,4) println(list) println(0::list)//使用雙冒號::將list集合和其他元素組成新的集合 var linkedList=scala.collection.mutable.LinkedList(1,12,2,3,5) while(linkedList!=Nil){//當集合中沒有元素時,返回Nil,head指第一個元素,tail指剩下的元素組成的集合 println(linkedList.head) linkedList=linkedList.tail } println(linkedList) val linkedList2=linkedList.+:(9) println("linkedList2: "+linkedList2) val set=Set(1,4,6,8) println("Set: "+set) var hashSet=scala.collection.mutable.HashSet(3,6,8,90) println("hashSet: "+hashSet) hashSet+=12 hashSet+=0 println("hashSet: "+hashSet) var linkedHashSet= scala.collection.mutable.LinkedHashSet(1,4,2,7,0) println("linkedHashSet: "+linkedHashSet) linkedHashSet+=3 linkedHashSet+=6 println("linkedHashSet: "+linkedHashSet) var sortSet=scala.collection.mutable.SortedSet(1,4,2,7,0) println("sortSet: "+sortSet) sortSet+=3 sortSet+=6 println("sortSet: "+sortSet) var li=List("hello my princess","this is mine !") println("li: "+li) var li_flatMap=li.flatMap( x => x.split(" ") )//flatMap根據函式操作生成新的集合 println("li_flatMap: "+li_flatMap) var li_flatMap_map=li_flatMap.map(x => (x ,"_kang"))//map對每個集合元素進行操作 println("li_flatMap_map: "+li_flatMap_map) var li_flatMap_map_map=li_flatMap_map.map(x =>x._2).reduce(_+_) println("li_flatMap_map_map: "+li_flatMap_map_map) //佔位符 List(1, 4, 2, 7, 0, 3, 6).foreach( x => println(x)) List(1, 4, 2, 7, 0, 3, 6).foreach( _ => println _ ) List(1, 4, 2, 7, 0, 3, 6).foreach( println(_)) List(1, 4, 2, 7, 0, 3, 6).foreach( println _ ) } }