Scala小白初学迭代器1.0

34 阅读3分钟

迭代器的定义

迭代器是一种用于遍历集合元素的对象。它提供了统一的方式来访问各种集合类 型(如列表、映射、集合等)中的元素,而不需要了解集合的内部结构。

在 Scala 中,迭代器是一种抽象的概念,它有特定的接口和方法来实现元素的遍历。

迭代器的基本使用

遍历输出List中的元素。

package it

/*
 * 迭代器
 *
 */
object it01 {
  def main(args: Array[String]): Unit = {
    val list1 = List(1,2,3,4,5)

    list1.foreach(ele => println(ele))

    // 3,4
    val iterator = list1.iterator
    // hasNext
    // next()
    while(iterator.hasNext){
      println(iterator.next())
    }
  }
}

注意:

  • next() 索取下一个,移动迭代器的位置。如果没有下一个,就报错
  • hasNext判断当前是否存在下一个元素:false,true
/*
 * 迭代器
 * 1. next() 索取下一个,移动迭代器的位置。如果没有下一个,就报错
 * 1. hasNext判断当前是否存在下一个元素:false,true
 */
object it02 {
  def main(args: Array[String]): Unit = {
    val it = List(1,2,3,4,5).iterator
    println(it.next())
    println(it.next())
    println(it.next())
    println(it.next())
    println(it.next())

    println(it.hasNext) // 当前是否还有 下一个元素

    // 第6次使用next,报错!!
    println(it.next())
  }
}

运行结果:

image.png

迭代器的优点

(1)内存效率高。迭代器采用延迟计算的方式,它不会将整个集合加载到内存中, 而是在每次调用next方法时才计算并返回下一个元素。

(2)统一的遍历方法。迭代器为不同类型的集合(如列表、集合、映射等)提供了 一种统一的遍历方式。无论底层集合的具体结构如何,只要能获取到迭代器,就 可以使用相同的hasNext和next方法来遍历元素。

(3)支持函数式编程风格,便于链式操作。

子迭代器(以 drop 和 take 为例

使用drop和take方法创建子迭代器。

drop方法会跳过指定数量的 元素,返回一个新的迭代器,而take方法会获取指定数量的元素作为一个新的迭 代器。

迭代器:

    1. next() 获取下一个,移动迭代器的位置。如果没有下一个,就报错
    1. hasNext判断当前是否存在下一个元素:false,true
    1. drop() 跳过指定数量的元素,返回一个新的迭代器
    1. take() 获取指定数量的元素,返回一个新的迭代器
/*
 * 迭代器
 * 1. next() 获取下一个,移动迭代器的位置。如果没有下一个,就报错
 * 2. hasNext判断当前是否存在下一个元素:false,true
 * 3. drop() 跳过指定数量的元素,返回一个新的迭代器
 * 4. take() 获取指定数量的元素,返回一个新的迭代器
 */

object it02 {
  def main(args: Array[String]): Unit = {
    val it = List(1,2,3,4,5).iterator
    //println(it.next())
    //println(it.next())
    //println(it.next())
    //println(it.next())
    //println(it.next())

    //println(it.hasNext) // 当前是否还有 下一个元素

    // 第6次使用next,报错!!
    //println(it.next())


    val it1=List(1,2,3,4,5).iterator
    // 跳过前两个元素
    val it2 = it1.drop(2)
    while(it2.hasNext){
      println(it2.next()) // 3 4 5
    }

    val it3=List(1,2,3,4,5).iterator
    it3.next()
    it3.next()
    val it4 = it3.take(2) // 获取指定数量的元素,返回一个新的迭代器
    while(it4.hasNext){
      println(it4.next()) // 3, 4
    }
  }
}