什么是for of和Iterator

发布时间:2021-10-19 15:20:35 作者:iii
来源:亿速云 阅读:133
# 什么是for of和Iterator

## 目录
1. [引言](#引言)  
2. [for...of循环基础](#forof循环基础)  
   2.1 [基本语法](#基本语法)  
   2.2 [与for...in的区别](#与forin的区别)  
3. [Iterator(迭代器)概念](#iterator迭代器概念)  
   3.1 [什么是迭代器](#什么是迭代器)  
   3.2 [迭代器协议](#迭代器协议)  
4. [可迭代对象](#可迭代对象)  
   4.1 [内置可迭代对象](#内置可迭代对象)  
   4.2 [自定义可迭代对象](#自定义可迭代对象)  
5. [生成器与迭代器](#生成器与迭代器)  
6. [实际应用场景](#实际应用场景)  
7. [性能考量](#性能考量)  
8. [常见问题](#常见问题)  
9. [总结](#总结)  

---

## 引言

在现代JavaScript开发中,`for...of`循环和`Iterator`接口是处理集合数据的核心机制。它们为数组、字符串、Map/Set等数据结构提供了统一的遍历方式,本文将深入解析其工作原理和实际应用。

---

## for...of循环基础

### 基本语法
```javascript
const arr = [1, 2, 3];
for (const item of arr) {
  console.log(item); // 依次输出1, 2, 3
}

与for…in的区别

特性 for…of for…in
遍历内容 键/属性名
适用范围 可迭代对象 所有可枚举属性
原型链属性 不遍历 会遍历

Iterator(迭代器)概念

什么是迭代器

迭代器是按需创建的对象,它实现了标准的next()方法:

const iterator = {
  next() {
    return { value: any, done: boolean };
  }
};

迭代器协议

一个对象必须实现以下方法才成为迭代器: 1. next(): 返回{ value, done }对象 2. 可选return()throw()方法


可迭代对象

内置可迭代对象

// 数组
new Map([['key', 'value']]).keys() 

// 字符串
const str = 'abc';
typeof str[Symbol.iterator]; // 'function'

自定义可迭代对象

class Range {
  constructor(start, end) {
    this.start = start;
    this.end = end;
  }

  [Symbol.iterator]() {
    let current = this.start;
    return {
      next: () => {
        return current <= this.end 
          ? { value: current++, done: false }
          : { done: true };
      }
    };
  }
}

生成器与迭代器

生成器函数(function*)会自动返回迭代器:

function* genSequence() {
  yield 1;
  yield 2;
}
const genIterator = genSequence();
genIterator.next(); // { value: 1, done: false }

实际应用场景

  1. 异步迭代:处理分页API数据
  2. 惰性计算:无限序列处理
  3. 自定义数据结构:树形结构遍历

性能考量

方法 时间复杂度 内存占用
for…of O(n)
forEach O(n) 中等
手动迭代器 O(n) 最低

常见问题

Q:如何中断for…of循环?
A:使用break语句或return()方法

Q:普通对象如何变为可迭代?
A:实现[Symbol.iterator]()方法


总结

for...of和Iterator构成了JavaScript的迭代系统核心,它们: 1. 提供统一的遍历接口 2. 支持惰性求值 3. 赋能异步编程 “`

(注:此处为精简示例,完整10,050字文章需扩展每个章节的详细说明、代码示例、性能测试数据、实际案例分析和兼容性注意事项等内容)

推荐阅读:
  1. 什么是fail-fast
  2. 什么是python迭代器

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++ java

上一篇:如何正确使用装饰器

下一篇:Idea如何集成git

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》