Scala | iterator 迭代器

65 阅读4分钟

一、迭代器的定义

1.迭代器是一种用于遍历集合元素的对象。

2.它提供了统一的方式来访问各种集合类型(如列表、映射、集合等)中的元素,而不需要了解集合的内部结构。

二、迭代器的基本使用

object iterator01 {

  def main(args: Array[String]): Unit = {

    val list1 = scala.collection.immutable.List(1,2,3,4,5)

//    list1.foreach(ele => {
//      println(ele)
//    })

    // 跳过list的前两个元素,而输出随后的两个
    val it = list1.iterator
    val it1 = it.drop(2).take(2)
    while(it1.hasNext) { // 3 4
      println(it1.next())
    }
  }
  
}

(1) iterator方法创建对应的迭代器。这个迭代器可以用于遍历列表中的元素。

(2) hasNext方法检查是否还有下一个元素。

(3) next方法获取一个元素

三、迭代器的优点

它的优点在于:
(1)内存效率高。迭代器采用延迟计算的方式,它不会将整个集合加载到内存中, 而是在每次调用next方法时才计算并返回下一个元素。
(2)统一的遍历方法。迭代器为不同类型的集合(如列表、集合、映射等)提供了 一种统一的遍历方式。无论底层集合的具体结构如何,只要能获取到迭代器,就 可以使用相同的hasNext和next方法来遍历元素。
(3)支持函数式编程风格,便于链式操作。

四、迭代器的常见方法

1. next方法

作用: 获取迭代器的下一个元素,并将迭代器的位置向前移动一位。

如果没有下一个元素,调用next方法会抛出 NoSuchElementException异常。

def main(args: Array[String]): Unit = {
    val list1 = List(1,2,3,4,5)

    // 访问这五个元素
  // 1.获取迭代器
    val it = list1.iterator
    // 输出当前的元素
    println(it.next()) // 获取 移动
    println(it.next())
    println(it.next())
    println(it.next())
    println(it.next())

    println(it.next()) // 越界     java.util.NoSuchElementException: head of empty list

  }

}

2.子迭代器(以 drop 和 take 为例)

我们可以使用drop和take方法创建子迭代器。

  • drop方法会跳过指定数量的元素,返回一个新的迭代器;
  • take方法会获取指定数量的元素作为一个新的迭代器。
def main(args: Array[String]): Unit = {
    val list1 = List(1,2,3,4,5)

    val it = list1.iterator

    val it2 = it.take(3) // take:从当前位置开始 只获取两个元素

    while(it2.hasNext) {
      println(it2.next()) // 1 2 3
    }
  }

}

3.duplicate复制迭代器

迭代器是一次性的:next之后,就不能再回头

  • 功能: 复制迭代器。返回一对迭代器,它们可以独立遍历原始迭代器中的元素序列。
  • 语法:(迭代器1,迭代器2) = 迭代器.duplicate()
  • 场景: 需要多次遍历同一个集合,但又不想重新创建迭代器或者影响原迭代器状 态的情况下非常有用。
  • 举例: 有一个迭代器包含了一系列的数值,你想要将这些数值分为两组,一组用 于计算平均值,另一组用于与平均值进行比较
def main(args: Array[String]): Unit = {
  val list1 = List(1,2,3,4,5)

  val it = list1.iterator
  
  val (it1, it2) = it.duplicate
  
  it.next()
  it.next()
  while(it1.hasNext) {
    println(it1.next()) // 3 4 5
  }
  println("-----------------")
  while(it2.hasNext) {
    println(it2.next()) // 3 4 5
  }
}

4.toList 方法

toList方法将迭代器中的剩余元素转换为一个列表。

def main(args: Array[String]): Unit = {
  val list1 = List(1,2,3,4,5)

  val it = list1.iterator


  it.next()
  it.next()
  println(it.next()) // 3

  // 希望把剩余的内容 装入一个新的List
  val newList = it.toList
  println(newList) // 4 5

}

运行结果:

屏幕截图 2025-12-08 092332.png

5.zip方法

  • zip方法用于将两个迭代器的元素按顺序组合成一个新的迭代器,其中每个元素是一个包含两个迭代器对应位置元素的元组。
  • 如果两个迭代器的长度不同, zip操作会在较短的迭代器耗尽时停止。
  • (两个迭代器的元素按照顺序组合成一个新的迭代器 长度不一,以短的为准)
def main(args: Array[String]): Unit = {
  val it1 = List(1,2,3,4,5).iterator
  val it2 = List("one","two","three","four","five").iterator

  val it3 = it1.zip(it2)

  while(it3.hasNext) {
    val pair = it3.next()
    println(pair._1, pair._2)
  }

}

运行结果:

屏幕截图 2025-12-08 093324.png