scala iterator(迭代器)
scala iterator(迭代器)不是一個集合,它是一種用于訪問集合的方法。
迭代器 it 的兩個基本操作是 next 和 hasnext。
調(diào)用 it.next() 會返回迭代器的下一個元素,并且更新迭代器的狀態(tài)。
調(diào)用 it.hasnext() 用于檢測集合中是否還有元素。
讓迭代器 it 逐個返回所有元素最簡單的方法是使用 while 循環(huán):
object test { def main(args: array[string]) { val it = iterator("baidu", "google", "yapf", "taobao") while (it.hasnext){ println(it.next()) } } }
執(zhí)行以上代碼,輸出結(jié)果為:
$ scalac test.scala $ scala test baidu google yapf taobao
1. 查找最大與最小元素
你可以使用 it.min 和 it.max 方法從迭代器中查找最大與最小元素,范例如下:
object test { def main(args: array[string]) { val ita = iterator(20,40,2,50,69, 90) val itb = iterator(20,40,2,50,69, 90) println("最大元素是:" + ita.max ) println("最小元素是:" + itb.min ) } }
執(zhí)行以上代碼,輸出結(jié)果為:
$ scalac test.scala $ scala test 最大元素是:90 最小元素是:2
2. 獲取迭代器的長度
你可以使用 it.size 或 it.length 方法來查看迭代器中的元素個數(shù)。范例如下:
object test { def main(args: array[string]) { val ita = iterator(20,40,2,50,69, 90) val itb = iterator(20,40,2,50,69, 90) println("ita.size 的值: " + ita.size ) println("itb.length 的值: " + itb.length ) } }
執(zhí)行以上代碼,輸出結(jié)果為:
$ scalac test.scala $ scala test ita.size 的值: 6 itb.length 的值: 6
3. scala iterator 常用方法
下表列出了 scala iterator 常用的方法:
序號 | 方法及描述 |
---|---|
1 |
def hasnext: boolean 如果還有可返回的元素,返回true。 |
2 |
def next(): a 返回迭代器的下一個元素,并且更新迭代器的狀態(tài) |
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] 迭代器都轉(zhuǎn)換成 bufferediterator |
8 |
def contains(elem: any): boolean 檢測迭代器中是否包含指定元素 |
9 |
def copytoarray(xs: array[a], start: int, len: int): unit 將迭代器中選定的值傳給數(shù)組 |
10 |
def count(p: (a) => boolean): int 返回迭代器元素中滿足條件p的元素總數(shù)。 |
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] 針對迭代器的序列中的每個元素應用函數(shù)f,并返回指向結(jié)果序列的迭代器。 |
19 |
def forall(p: (a) => boolean): boolean 返回一個布爾值,指明 it 所指元素是否都滿足p。 |
20 |
def foreach(f: (a) => unit): unit 在迭代器返回的每個元素上執(zhí)行指定的程序 f |
21 |
def hasdefinitesize: boolean 如果迭代器的元素個數(shù)有限則返回 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 返回迭代器元素的數(shù)量。 |
27 |
def map[b](f: (a) => b): iterator[b] 將 it 中的每個元素傳入函數(shù) f 后的結(jié)果生成新的迭代器。 |
28 |
def max: a 返回迭代器迭代器元素中最大的元素。 |
29 |
def min: a 返回迭代器迭代器元素中最小的元素。 |
30 |
def mkstring: string 將迭代器所有元素轉(zhuǎn)換成字符串。 |
31 |
def mkstring(sep: string): string 將迭代器所有元素轉(zhuǎn)換成字符串,并指定分隔符。 |
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 返回迭代器所指數(shù)值型元素的積。 |
36 |
def sameelements(that: iterator[_]): boolean 判斷迭代器和指定的迭代器參數(shù)是否依次返回相同元素 |
37 |
def seq: iterator[a] 返回集合的系列視圖 |
38 |
def size: int 返回迭代器的元素數(shù)量 |
39 |
def slice(from: int, until: int): iterator[a] 返回一個新的迭代器,指向迭代器所指向的序列中從開始于第 from 個元素、結(jié)束于第 until 個元素的片段。 |
40 |
def sum: a 返回迭代器所指數(shù)值型元素的和 |
41 |
def take(n: int): iterator[a] 返回前 n 個元素的新迭代器。 |
42 |
def toarray: array[a] 將迭代器指向的所有元素歸入數(shù)組并返回。 |
43 |
def tobuffer: buffer[b] 將迭代器指向的所有元素拷貝至緩沖區(qū) 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 將迭代器轉(zhuǎn)換為字符串 |
50 |
def zip[b](that: iterator[b]): iterator[(a, b) 返回一個新迭代器,指向分別由迭代器和指定的迭代器 that 元素一一對應而成的二元組序列 |
更多方法可以參考 api文檔
- JDBC 教程
- JDBC 驅(qū)動類型
- JDBC 連接數(shù)據(jù)庫范例
- JDBC 連接數(shù)據(jù)庫步驟
- JDBC Statement, PreparedStatement 和 CallableStatement
- JDBC ResultSet 結(jié)果集
- JDBC Resultset 結(jié)果集范例
- JDBC 事務保存點范例
- Scala 教程
- Scala 簡介
- Scala 類和對象
- Scala 文件 I/O
- Spring 教程
- Spring 模塊
- Spring 依賴注入
- Spring 自動裝配
- Spring MVC教程
- Spring MVC表單標簽庫
- Spring security