首页 > 其他分享 >迭代器

迭代器

时间:2023-02-10 11:56:58浏览次数:37  
标签:遍历 迭代 iterator next done 数据结构

介绍

  迭代器(iterator)是一种接口,为各种不同的数据结构提供统一的访问机制。

任何数据结构只要部署iterator借口,就可以完成遍历操作。

1.ES6创造了一种新的遍历命令for...of循环,ierator接口主要供for...of消费

2.原生具备iterator借口的数据(可用for  of遍历) 

3.工作原理

  创建一个指针对象,指向当前数据结构的起始位置

  第一次调用对象的next方法,指针自动指向数据结构的第一个成员

  接下来不断调用next方法,指针一直往后移动,直到指向最后一个成员

注意:

  需要自定义遍历数据的时候,要想到迭代器。

创建

迭代器的本身是一个对象,这个对象有 next( ) 方法返回结果对象,这个结果对象有下一个返回值 value、迭代完成布尔值 done,模拟创建一个简单迭代器如下:

function createIterator(iterms) {
 let i = 0
 return {
  next() {
   let done = (i >= iterms.length)
   let value = !done ? iterms[i++] : undefined
   return {
    done,
    value
   }
  }
 }
}

 

标签:遍历,迭代,iterator,next,done,数据结构
From: https://www.cnblogs.com/0722tian/p/17108074.html

相关文章