1. 程式人生 > >Scala:集合型別Collection和迭代器

Scala:集合型別Collection和迭代器

Scala Collection

Scala 集合分為可變的和不可變的集合。

可變集合可以在適當的地方被更新或擴充套件。這意味著你可以修改,新增,移除一個集合的元素。

而不可變集合類,相比之下,永遠不會改變。不過,你仍然可以模擬新增,移除或更新操作。但是這些操作將在每一種情況下都返回一個新的集合,同時使原來的集合不發生改變。

集合型別的應用

1     Scala List(列表)
List的特徵是其元素以線性方式儲存,集合中可以存放重複物件。
2     Scala Set(集合)
Set是最簡單的一種集合。集合中的物件不按特定的方式排序,並且沒有重複物件。
3     Scala Map(對映)
Map 是一種把鍵物件和值物件對映的集合,它的每一個元素都包含一對鍵物件和值物件。
4     Scala 元組
元組是不同型別的值的集合
5     Scala Option
Option[T] 表示有可能包含值的容器,也可能不包含值。
6     Scala Iterator(迭代器)
迭代器不是一個容器,更確切的說是逐一訪問容器內元素的方法。

例項

以下程式碼判斷,演示了所有以上集合型別的定義例項:

// 定義整型 List
val x =List(1,2,3,4)// 定義 Setvar x =Set(1,3,5,7)// 定義 Map
val x =Map("one"->1,"two"->2,"three"->3)// 建立兩個不同型別元素的元組
val x =(10,"Runoob")// 定義 Option
val x:Option[Int]=Some(5)

Scala Iterator(迭代器)

Scala Iterator(迭代器)不是一個集合,它是一種用於訪問集合的方法。

迭代器 it 的兩個基本操作是 nexthasNext

呼叫 it.next() 會返回迭代器的下一個元素,並且更新迭代器的狀態。

呼叫 it.hasNext() 用於檢測集合中是否還有元素。

讓迭代器 it 逐個返回所有元素最簡單的方法是使用 while 迴圈:

objectTest{def main(args:Array[String]){
      val it =Iterator("Baidu","Google","Runoob","Taobao")while(it.hasNext){
         println(it.next())}}}

Scala Iterator 常用方法

序號方法及描述
1

def hasNext: Boolean

如果還有可返回的元素,返回true。

2

def next(): A

返回迭代器的下一個元素,並且更新迭代器的狀態

3

def ++(that: => Iterator[A]): Iterator[A]

合併兩個迭代器

4

def ++[B >: A](that :=> GenTraversableOnce[B]): Iterator[B]

合併兩個迭代器

5

def addString(b: StringBuilder): StringBuilder

新增一個字串到 StringBuilder b

6

def addString(b: StringBuilder, sep: String): StringBuilder

新增一個字串到 StringBuilder b,並指定分隔符

7

def buffered: BufferedIterator[A]

迭代器都轉換成 BufferedIterator

8

def contains(elem: Any): Boolean

檢測迭代器中是否包含指定元素

9

def copyToArray(xs: Array[A], start: Int, len: Int): Unit

將迭代器中選定的值傳給陣列

10

def count(p: (A) => Boolean): Int

返回迭代器元素中滿足條件p的元素總數。

11

def drop(n: Int): Iterator[A]

返回丟棄前n個元素新集合

12

def dropWhile(p: (A) => Boolean): Iterator[A]

從左向右丟棄元素,直到條件p不成立

13

def duplicate: (Iterator[A], Iterator[A])

生成兩個能分別返回迭代器所有元素的迭代器。

14

def exists(p: (A) => Boolean): Boolean

返回一個布林值,指明迭代器元素中是否存在滿足p的元素。

15

def filter(p: (A) => Boolean): Iterator[A]

返回一個新迭代器 ,指向迭代器元素中所有滿足條件p的元素。

16

def filterNot(p: (A) => Boolean): Iterator[A]

返回一個迭代器,指向迭代器元素中不滿足條件p的元素。

17

def find(p: (A) => Boolean): Option[A]

返回第一個滿足p的元素或None。注意:如果找到滿足條件的元素,迭代器會被置於該元素之後;如果沒有找到,會被置於終點。

18

def flatMap[B](f: (A) => GenTraversableOnce[B]): Iterator[B]

針對迭代器的序列中的每個元素應用函式f,並返回指向結果序列的迭代器。

19

def forall(p: (A) => Boolean): Boolean

返回一個布林值,指明 it 所指元素是否都滿足p。

20

def foreach(f: (A) => Unit): Unit

在迭代器返回的每個元素上執行指定的程式 f

21

def hasDefiniteSize: Boolean

如果迭代器的元素個數有限則返回true(預設等同於isEmpty)

22

def indexOf(elem: B): Int

返回迭代器的元素中index等於x的第一個元素。注意:迭代器會越過這個元素。

23

def indexWhere(p: (A) => Boolean): Int

返回迭代器的元素中下標滿足條件p的元素。注意:迭代器會越過這個元素。

24

def isEmpty: Boolean

檢查it是否為空, 為空返回 true,否則返回false(與hasNext相反)。

25

def isTraversableAgain: Boolean

Tests whether this Iterator can be repeatedly traversed.

26

def length: Int

返回迭代器元素的數量。

27

def map[B](f: (A) => B): Iterator[B]

將 it 中的每個元素傳入函式 f 後的結果生成新的迭代器。

28

def max: A

返回迭代器迭代器元素中最大的元素。

29

def min: A

返回迭代器迭代器元素中最小的元素。

30

def mkString: String

將迭代器所有元素轉換成字串。

31

def mkString(sep: String): String

將迭代器所有元素轉換成字串,並指定分隔符。

32

def nonEmpty: Boolean

檢查容器中是否包含元素(相當於 hasNext)。

33

def padTo(len: Int, elem: A): Iterator[A]

首先返回迭代器所有元素,追加拷貝 elem 直到長度達到 len。

34

def patch(from: Int, patchElems: Iterator[B], replaced: Int): Iterator[B]

返回一個新迭代器,其中自第 from 個元素開始的 replaced 個元素被迭代器所指元素替換。

35

def product: A

返回迭代器所指數值型元素的積。

36

def sameElements(that: Iterator[_]): Boolean

判斷迭代器和指定的迭代器引數是否依次返回相同元素

37

def seq: Iterator[A]

返回集合的系列檢視

38

def size: Int

返回迭代器的元素數量

39

def slice(from: Int, until: Int): Iterator[A]

返回一個新的迭代器,指向迭代器所指向的序列中從開始於第 from 個元素、結束於第 until 個元素的片段。

40

def sum: A

返回迭代器所指數值型元素的和

41

def take(n: Int): Iterator[A]

返回前 n 個元素的新迭代器。

42

def toArray: Array[A]

將迭代器指向的所有元素歸入陣列並返回。

43

def toBuffer: Buffer[B]

將迭代器指向的所有元素拷貝至緩衝區 Buffer。

44

def toIterable: Iterable[A]

Returns an Iterable containing all elements of this traversable or iterator. This will not terminate for infinite iterators.

45

def toIterator: Iterator[A]

把迭代器的所有元素歸入一個Iterator容器並返回。

46

def toList: List[A]

把迭代器的所有元素歸入列表並返回

47

def toMap[T, U]: Map[T, U]

將迭代器的所有鍵值對歸入一個Map並返回。

48

def toSeq: Seq[A]

將代器的所有元素歸入一個Seq容器並返回。

49

def toString(): String

將迭代器轉換為字串

50

def zip[B](that: Iterator[B]): Iterator[(A, B)

返回一個新迭代器,指向分別由迭代器和指定的迭代器 that 元素一一對應而成的二元組序列

ref: