lterator遍历
2024-09-06 06:06:47
iterator是一种接口机制,为各种不同的数据结构提供统一的访问机制
作用:
1、为各种数据结构,提供一个统一的、简便的访问接口;
2、使得数据结构的成员能够按某种次序排列
3、ES6创造了一种新的遍历命令for...of循环,Iterator接口主要供for...of消费。
工作原理:
- 创建一个指针对象,指向数据结构的起始位置。
- 第一次调用next方法,指针自动指向数据结构的第一个成员
- 接下来不断调用next方法,指针会一直往后移动,直到指向最后一个成员
- 每调用next方法返回的是一个包含value和done的对象,{value: 当前成员的值,done: 布尔值}
* value表示当前成员的值,done对应的布尔值表示当前的数据的结构是否遍历结束。
* 当遍历结束的时候返回的value值是undefined,done值为false
原生具备iterator接口的数据(可用for of遍历)
1、Array
2、arguments
3、set容器
4、map容器
5、String
// 自定义iterator生成指针对象
function mockIterator(arr) {
let nextIndex = ;
return {
next: function () {
return nextIndex<arr.length?{value: arr[nextIndex++], done: false}:{value: undefined, done: true}
}
}
} let arr = [,,,,];
let iteratorObj = mockIterator(arr);
console.log(iteratorObj.next());
console.log(iteratorObj.next());
console.log(iteratorObj.next());
// 使用解构赋值以及...三点运算符时会调用iterator接口 let arr1 = [,,,,];
let [value1, ...arr2] = arr1;
// yield*语句
function* generatorObj() {
yield ''; // 可遍历数据,会自动调用iterator函数
yield '';
}
let Go = generatorObj();
console.log(Go.next());
console.log(Go.next());
console.log(Go.next());
// 原生测试 数组
let arr3 = [, , 'kobe', true];
for(let i of arr3){
console.log(i);
}
// 字符串 string
let str = 'abcdefg';
for(let item of str){
console.log(item);
}
最新文章
- 【第一篇】ASP.NET MVC快速入门之数据库操作(MVC5+EF6)
- 创建一个带模版的用户控件 V.2
- Java之Structs框架初探
- 电脑IP改变后oracle em无法登陆的解决办法(亲测)
- C语言超级经典400道题目
- JSP合用html5 尝试(一)
- ADO.Net连接模式
- docker的一些命令
- 快速排序时间复杂度为O(n&#215;log(n))的证明
- PAT (Basic Level) Practise (中文) 1023. 组个最小数 (20)
- windows wmi
- linux 操作 json文件
- day32 process模块用法
- 37.Spring-事务控制.md
- JS实现数组去重方法总结(三种常用方法)
- 「SDOI2008」Sandy 的卡片
- NET二进制图片存储与读取的常见方法,iTextSharp添加图片生成PDF文件
- java maven项目找不到jconsole-1.8.0.jar和tools-1.8.0.jar包
- 18-javaweb-ssm 开发中错误总结
- .PHONY makefile中的伪目标