zoukankan      html  css  js  c++  java
  • 【scala】迭代器

    如何访问集合呢?我们首先想到的是使用for循环来访问,还有一种方法是通过迭代器来访问。

    在Scala中,迭代器(Iterator)不是一个集合,但是,提供了访问集合的一种方法。

    迭代器包含两个基本的操作:1.next(),可以返回迭代器的下一个元素 2.hasnext(),检测是否还有下一个元素

    示例
      

    val iter = Iterator("Hadoop","Spark","Java");//定义一个迭代器
    while(iter.hasnext()){
        println(iter.next())  
    }
    

    当然我们还可以通过for来遍历迭代器

    for(elem <- iter){
        println(elem)  
    }
    

    迭代器还有不同的种类,当我们使用容器的grouped和siding方法的时候将返回两种功能不同的迭代器。

    这两种迭代器返回的不是单个元素,而是原来容器元素的全部子序列。

    grouped方法返回的是元素的增量分块。

    val xs= Lisr(1,2,3,4,5);
    val git =xs grouped 3;
    //注意这种写法等同于:val git = xs.grouped(3);
    //再例如,a + b  等同于 a.+(b)   
    //因为scala中所有都是对象
    println(git.next());   ---> List(1,2,3)
    println(git.next());   ---->List(4,5)
    //我们注意到,grouped(3)是以3个元素为单位分组归并为一个迭代器单元,最后不够不补齐

    sliding方法生成一个滑动元素的窗口。

    val xs= Lisr(1,2,3,4,5);
    val git =xs sliding 3;//等同于:val git = xs.sliding(3);
    println(git.next());   ---> List(1,2,3)
    println(git.next());   ---->List(2,3,4)
    println(git.next());   ---->List(3,4,5)
    //我们注意到,sliding(3)是以原容器3个元素为单位分组归并为一个迭代器单元
    //然后推进一个元素,再以3个元素为单位归并为一个迭代器单元,直到结束
    

    迭代器还有一些其他常用的方法

    获取迭代器的长度   iter.size   iter.length

    我们同样还能用迭代器来找出最大最小元素

    val ita = Iterator(20,40,2,50,69, 90);
    val itb = Iterator(20,40,2,50,69, 90);  
    println("迭代长度是:" + ita.length );
    println("迭代长度是:" + itb.size);
    println("最大元素是:" + ita.max );   --> 90
    println("最小元素是:" + ita.min );  --> 2

    细心的同学可以发现,min和max是从两个迭代器中求出的,我们难道不能使用同一个迭代器吗?

    是不可以的,因为每个迭代器只能迭代一次

    就是说,一个迭代器从头到尾求出了最大值,就完了,并不能再从头来过找最小值,只能另建立一个相同迭代器来找最小值。

    下面给出迭代器的所有方法

    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 元素一一对应而成的二元组序列

      

  • 相关阅读:
    android 之短信发送
    android 系统之ContentProvider
    android 开发电话拔号
    android 开发笔记
    android 常用权限备份
    在IE中使用Firebug
    常用的公式语言
    ASP.NET程序访问MS SQL的方法
    [News]将有新的代码生成工具集成在designer 8.5.1中
    JS对Lotus域的操作
  • 原文地址:https://www.cnblogs.com/zzhangyuhang/p/8909856.html
Copyright © 2011-2022 走看看