Scala编程基础22:Scala迭代器

Scala迭代器不是一个集合,它是一种用于访问集合的方法。迭代器的两个基本操作是next和hasNext。调用it.next()会返回集合的下一个元素,并且更新迭代器的状态。调用it.hasNext方法用于检测集合中是否还有元素。让迭代器逐个返回所有元素的最简单的方法就是使用while循环。

1.迭代器的定义和使用

下面是一个定义使用迭代器的示例:

object Test1 {
    def main(args:Array[String]){
        val it = Iterator("Hello","Scala","I","Love","You");
        while(it.hasNext){
            println(it.next());
        }
    }
}

编译并执行以上代码,输出结果如下:

E:\Test>scalac Test1.scala
E:\Test>scala Test1
Hello
Scala
I
Love
You

2.查找最大值和最小值

可以使用it.max和it.min方法查找迭代器中的最大最小值:

object Test2 {
    def main(args:Array[String]){
        val it1 = Iterator(5,2,3,4,1);
        val it2 = Iterator(5,2,3,4,1);
        println("max = " + it1.max);
        println("min = " + it2.min);
    }
}

编译并执行以上代码,输出结果如下:

E:\Test>scalac Test2.scala
E:\Test>scala Test2
max = 5
min = 1

3.获取迭代器的长度

可以使用it.size或者it.length方法来查看迭代器中的元素个数:

object Test3 {
    def main(args:Array[String]){
        val it1 = Iterator(5,2,3,4,1);
        val it2 = Iterator(5,2,3,4,1);
        println("it.size = " + it1.size);
        println("it.length = " + it2.length);
    }
}

编译并执行以上代码,输出结果如下:

E:\Test>scalac Test3.scala
E:\Test>scala Test3
it.size = 5
it.length = 5

4.Scala迭代器常用方法

下面列出了Scala Iterator中常用的方法:

def hasNext: Boolean
如果还有可返回的元素,返回true。

def next(): A
返回迭代器的下一个元素,并且更新迭代器的状态

def ++(that: => Iterator[A]): Iterator[A]
合并两个迭代器

def ++[B >: A](that :=> GenTraversableOnce[B]): Iterator[B]
合并两个迭代器

def addString(b: StringBuilder): StringBuilder
添加一个字符串到 StringBuilder b

def addString(b: StringBuilder, sep: String): StringBuilder
添加一个字符串到 StringBuilder b,并指定分隔符

def buffered: BufferedIterator[A]
迭代器都转换成 BufferedIterator

def contains(elem: Any): Boolean
检测迭代器中是否包含指定元素

def copyToArray(xs: Array[A], start: Int, len: Int): Unit
将迭代器中选定的值传给数组

def count(p: (A) => Boolean): Int
返回迭代器元素中满足条件p的元素总数。

def drop(n: Int): Iterator[A]
返回丢弃前n个元素新集合

def dropWhile(p: (A) => Boolean): Iterator[A]
从左向右丢弃元素,直到条件p不成立

def duplicate: (Iterator[A], Iterator[A])
生成两个能分别返回迭代器所有元素的迭代器。

def exists(p: (A) => Boolean): Boolean
返回一个布尔值,指明迭代器元素中是否存在满足p的元素。

def filter(p: (A) => Boolean): Iterator[A]
返回一个新迭代器 ,指向迭代器元素中所有满足条件p的元素。

def filterNot(p: (A) => Boolean): Iterator[A]
返回一个迭代器,指向迭代器元素中不满足条件p的元素。

def find(p: (A) => Boolean): Option[A]
返回第一个满足p的元素或None。注意:如果找到满足条件的元素,迭代器会被置于该元素之后;如果没有找到,会被置于终点。

def flatMap[B](f: (A) => GenTraversableOnce[B]): Iterator[B]
针对迭代器的序列中的每个元素应用函数f,并返回指向结果序列的迭代器。

def forall(p: (A) => Boolean): Boolean
返回一个布尔值,指明 it 所指元素是否都满足p。

def foreach(f: (A) => Unit): Unit
在迭代器返回的每个元素上执行指定的程序 f

def hasDefiniteSize: Boolean
如果迭代器的元素个数有限则返回true(缺省等同于isEmpty)

def indexOf(elem: B): Int
返回迭代器的元素中index等于x的第一个元素。注意:迭代器会越过这个元素。

def indexWhere(p: (A) => Boolean): Int
返回迭代器的元素中下标满足条件p的元素。注意:迭代器会越过这个元素。

def isEmpty: Boolean
检查it是否为空, 为空返回 true,否则返回false(与hasNext相反)。

def isTraversableAgain: Boolean
Tests whether this Iterator can be repeatedly traversed.

def length: Int
返回迭代器元素的数量。

def map[B](f: (A) => B): Iterator[B]
将 it 中的每个元素传入函数 f 后的结果生成新的迭代器。

def max: A
返回迭代器迭代器元素中最大的元素。

def min: A
返回迭代器迭代器元素中最小的元素。

def mkString: String
将迭代器所有元素转换成字符串。

def mkString(sep: String): String
将迭代器所有元素转换成字符串,并指定分隔符。

def nonEmpty: Boolean
检查容器中是否包含元素(相当于 hasNext)。

def padTo(len: Int, elem: A): Iterator[A]
首先返回迭代器所有元素,追加拷贝 elem 直到长度达到 len。

def patch(from: Int, patchElems: Iterator[B], replaced: Int): Iterator[B]
返回一个新迭代器,其中自第 from 个元素开始的 replaced 个元素被迭代器所指元素替换。

def product: A
返回迭代器所指数值型元素的积。

def sameElements(that: Iterator[_]): Boolean
判断迭代器和指定的迭代器参数是否依次返回相同元素

def seq: Iterator[A]
返回集合的系列视图

def size: Int
返回迭代器的元素数量

def slice(from: Int, until: Int): Iterator[A]
返回一个新的迭代器,指向迭代器所指向的序列中从开始于第 from 个元素、结束于第 until 个元素的片段。

def sum: A
返回迭代器所指数值型元素的和

def take(n: Int): Iterator[A]
返回前 n 个元素的新迭代器。

def toArray: Array[A]
将迭代器指向的所有元素归入数组并返回。

def toBuffer: Buffer[B]
将迭代器指向的所有元素拷贝至缓冲区 Buffer。

def toIterable: Iterable[A]
返回包含此遍历或迭代器的所有元素的Iterable。 对于无限迭代器,这不会终止。

def toIterator: Iterator[A]
把迭代器的所有元素归入一个Iterator容器并返回。

def toList: List[A]
把迭代器的所有元素归入列表并返回

def toMap[T, U]: Map[T, U]
将迭代器的所有键值对归入一个Map并返回。

def toSeq: Seq[A]
将代器的所有元素归入一个Seq容器并返回。

def toString(): String
将迭代器转换为字符串

def zip[B](that: Iterator[B]): Iterator[(A, B)
返回一个新迭代器,指向分别由迭代器和指定的迭代器 that 元素一一对应而成的二元组序列

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容