一天学完spark的Scala基础语法教程九、迭代器(idea版本)
📋前言📋
💝博客主頁:紅目香薰_CSDN博客-大數據,計算機理論,MySQL領域博主💝
?本文由在下【紅目香薰】原創,首發于CSDN?
🤗2022年最大愿望:【服務百萬技術人次】🤗
💝初始環境地址:【spark環境搭建(idea版本)_紅目香薰-CSDN博客】💝
環境需求
環境:win10
開發工具:IntelliJ IDEA 2021.2
maven版本:3.6.3
創建測試類【day1/demo9.scalc】,文件類型【object】
Scala Iterator(迭代器)
Scala Iterator(迭代器)不是一個集合,它是一種用于訪問集合的方法。
迭代器 it 的兩個基本操作是?next?和?hasNext。
調用?it.next()?會返回迭代器的下一個元素,并且更新迭代器的狀態。
調用?it.hasNext()?用于檢測集合中是否還有元素。
讓迭代器 it 逐個返回所有元素最簡單的方法是使用 while 循環:
package day1object demo9 {def main(args: Array[String]) {val it = Iterator("琢石", "璞玉", "破夢", "滅神")while (it.hasNext){println(it.next())}} }查找最大與最小元素
package day1object demo9 {def main(args: Array[String]) {val a = Iterator(20,410,21,50,629, 9110)val b = Iterator(20,410,21,50,629, 920)println("最大元素是:" + a.max )println("最小元素是:" + b.min )} }?
獲取迭代器的長度
package day1object demo9 {def main(args: Array[String]) {val a = Iterator(20,410,21,50,629, 9110)val b = Iterator(20,410,21,50,629, 920)println("a.size 的值: " + a.size )println("b.length 的值: " + b.length )} }Scala Iterator 常用方法
下表列出了 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 元素一一對應而成的二元組序列 |
總結
到這里有關一天學完spark的Scala基礎語法教程九、迭代器(idea版本)就結束了
希望能對大家有所幫助。
歡迎一鍵三連,謝謝。
總結
以上是生活随笔為你收集整理的一天学完spark的Scala基础语法教程九、迭代器(idea版本)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 一天学完spark的Scala基础语法教
- 下一篇: 一天学完spark的Scala基础语法教