一:迭代器的定义
迭代器是一种用于遍历集合元素的对象。它提供了统一的方式来访问各种集合类 型(如列表、映射、集合等)中的元素,而不需要了解集合的内部结构。
在 Scala 中,迭代器是一种抽象的概念,它有特定的接口和方法来实现元素的遍历。
二:迭代器的基本使用
我们来看实际的需求。遍历输出List中的元素。
// 创建一个整数列表
val list = List(1, 2, 3, 4, 5)
// 通过 iterator 方法创建对应的迭代器
val iterator = list.iterator
while (iterator.hasNext) {
println(iterator.next())
}
(1) iterator方法创建对应的迭代器。这个迭代器可以用于遍历列表中的元素。
(2) hasNext方法检查是否还有下一个元素。
(3) next方法获取一个元素
使用迭代器的基本步骤是:
第一步:构建一个迭代器
第二步:循环获取元素
三:迭代器的优点
(1)内存效率高。迭代器采用延迟计算的方式,它不会将整个集合加载到内存中, 而是在每次调用next方法时才计算并返回下一个元素。
(2)统一的遍历方法。迭代器为不同类型的集合(如列表、集合、映射等)提供了 一种统一的遍历方式。无论底层集合的具体结构如何,只要能获取到迭代器,就 可以使用相同的hasNext和next方法来遍历元素。
(3)支持函数式编程风格,便于链式操作。
package iterator
//next():获取当前的元素并移动到下一次迭代器
//hasNext:判断是否有下一个元素
//drop(n):从当前位置开始跳过n个元素并返回一个新的迭代器
//take(n):从当前位置开始获取n个元素并返回一个新的迭代器
//duplicate:复制迭代器
//toList:把迭代器中剩余的元素放在一个新的List中
//zip:把两个迭代器合并为一个迭代器可以同步移动这两个迭代器并以短的为准
object Demo01 {
def main(args: Array[String]): Unit = {
val sc4 = List(1,2,3,4,5,6).iterator
val sc5 = List("one","two","three","four").iterator
val sc6 = sc5.zip(sc4)
while(sc6.hasNext){
val sc7 =sc6.next()
println(sc7)
}
val list = List(1,2,3,4,5).iterator
list.foreach(sc =>println(sc))
val (sc1, sc2) = list.duplicate
while(sc2.hasNext){
println(sc2.next())
}
// sc1.next()
// sc1.next()
// val sc3 = sc1.toList
// println(sc3)
// val scc = list.iterator.drop(4).take(1)
// while(scc.hasNext){
// println(scc.next()) //跳过2个元素到3,并输出3个元素为3,4,5
// }
// println(scc.next()) 超过最大元素5后next报错
}
}