迭代器Iterator和生成器funcion *

news2025/1/11 14:13:14

迭代器Iterator

迭代器 为各种不同的数据结果提供统一的访问机制,任何数据结构只要部署Iterator接口,就可以完成便利操作,主要提供for of
工作原理:
创建一个指针对象,指向当前数组的起始位置
第一次调用对象的next方法,会自动指向数据接口的第一个成员
接下来不断用next方法,指针会一直往后移动,直到指向最后一个成员
目前 数组 Set Map 字符串他们的原型上有Symbol.interator,表示可以进行迭代器
在这里插入图片描述
只要原型上有Symbol.iterator属性那么就能调用迭代器的next( ) 方法

object原型上是没有Symbol.iterator属性,因为javascript认为object可以直接通过调用key来获取对应的值,不存在顺序调用。

//数组
let arr = [12, 3, 4, 5, 6, 7]
let it = arr[Symbol.iterator]()
it.next() // 12
it.next() // 3
it.next() // 4
...
//Set
let set = new Set([1, 3, 4, 3, 7])
let seti = set[Symbol.iterator]()
seti.next() // 1
seti.next() // 3
seti.next() // 4
let map = new Map([['q', 1]['w', 2]])
let mapi = map[Symbol.iterator]()
mapi.next()

如何给对象添加Symbol.iterator,使他能够使用for of循环

// 需求:现在需要遍历这个对象 必须使用for of遍历,每次返回的是stus的成员 
const banjin = {
  name: 'yiban',
  stus: [
    'xiaoming',
    'xiaogang',
    'xiaohong',
    'xiaowang'
  ]
}

const banjin = {
  name: 'yiban',
  stus: [
    'xiaoming',
    'xiaogang',
    'xiaohong',
    'xiaowang'
  ],
  [Symbol.iterator]() {
    let index = 0
    let that = this // 让this指向当前对象,或者下面使用尖头函数
    return {
      next: function () {
       // return { value: '111', done: false }   // 如果这样些会一直输出,应为一直没有结束 
        if (index < that.stus.length) {
          index++ // 下标自增,不然index永远为0
          return { value: that.stus[index], done: false }
        } else {
          return { value: undefined, done: true }
        }
      }
    }
  }
}

for (let i of banjin) {
  console.log(i); // 会提示:TypeError:banji is not iterate ,说明班级这个变量它不能迭代 
}

生成器函数

生成器是ES6中新增的一种函数控制、使用的方案,它可以让我们更加灵活的控制函数什么时候继续执行、暂停执行

生成器函数也是一个函数,但是和普通的函数有一些区别:
生成器函数需要在function的后面加一个符号:*
生成器函数可以通过yield关键字来控制函数的执行流程
生成器函数的返回值是一个Generator(生成器)

生成器事实上是一种特殊的迭代器

//普通生成器调用
function* foo() {
  yield console.log("01")
  yield console.log("02")
  yield console.log("03")
}
const fooi = foo()
fooi.next() // 01
fooi.next() // 02
fooi.next() // 03

生成器异步调用

//实现一个借接口请求 loading加载 异步请求数组 loading消失 加上上一次的结果作为下次的参数使用

function pro1() {
  console.log('第一次调用loading'); 
}

function pro2() {
  setTimeout(() => {
    console.log('第二次调用异步加载数据,加载成功之后在关闭loading');
    const num = 1000 // 比如这个请求成的结果参数 传到下个请求中
    proi.next(num)
  }, 2000);
}

// x: 上一个请求获得结果作为参数传入
function pro3(x) {
  console.log('第三次调用关闭loadin',x); // 1000 
}

function * pro() {
  pro1()
  let x = yield pro2()
  let y = yield pro3(x)
}
const proi = pro()
proi.next()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/580485.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JAVA之数组2

添加元素 从后往前进行迭代&#xff0c;最后在末尾插入元素 tip&#xff1a;为避免数字在覆盖过程中丢失&#xff0c;故从后往前覆盖 删除元素 从前往后迭代&#xff0c;最后将末尾赋值为0 tip: 以覆盖的数arr【i】为基准&#xff0c;构造循环 共同处Tip: 范围均为【index1&…

子串--子字符串 0528

210102 201012 A1A2…An An…A2A1 如何做&#xff0c; 翻转的是21&#xff0c;因为2>1; 翻转的是210&#xff0c;因为2>0; 翻转的是2101&#xff0c;因为2>1&#xff1b; 翻转的是21010&#xff0c;因为2>0&#xff1b; 翻转的是210102&#xff0c;因为22且1&…

JavaScript 进阶 (二)

目录 深入对象 创建对象三种方式 构造函数 实例成员&静态成员 内置构造函数 Object Array String Number 深入对象 创建对象三种方式 1. 利用对象字面量创建对象 const obj { name : abc} 2. 利用 new Object 创建对象 const obj new Object({ uname: 123 }…

如何评估一个好的物业系统开发方案?

在当前不断变化的物业管理市场中&#xff0c;物业系统已成为物业管理公司提高管理效率和降低成本的必然选择。因此&#xff0c;如何评估一个好的物业系统开发方案成为了每个物业管理决策者必须面对的重要问题。在本文中&#xff0c;我们将介绍如何从以下几个方面来评估一个好的…

文心一言 VS 讯飞星火 VS chatgpt (24)-- 算法导论4.2 6题

六、用Strassen 算法作为子进程来进行一个 knn 矩阵和一个nkn 矩阵相乘&#xff0c;最快需要花费多长时间?对两个输入矩阵规模互换的情况&#xff0c;回答相同的问题。 文心一言&#xff1a; Strassen 算法是一种用于矩阵乘法的分治算法&#xff0c;它将原始的矩阵分解为较小…

腾讯云产品首单特惠是什么意思?包括新用户老用户的解答

腾讯云最近推出的活动限制条件为产品首单特惠&#xff0c;但是有的用户购买不了&#xff0c;右上角提示“产品首单特惠”&#xff0c;那么什么是产品首单特惠&#xff1f;什么是新用户&#xff1f;什么是老用户&#xff1f;新手站长给大家&#xff1a; 腾讯云产品首单特惠是什…

【Linux】Pinctrl子系统简介

前言&#xff1a; 我们工作开发中非常常用的就是GPIO&#xff0c;在Linux开发中&#xff0c;是有必要去熟悉并理解的。在Linux内核中也有提供相应的子系统pinctrl子系统&#xff0c;本文从大的面上去了解它。 参考学习&#xff1a;Linux笔记老师课程&#xff08;Pinctrl子系统&…

CentOS 7.6 (Linux)环境上离线安装 MySQL 8

1 下载安装包 访问https://dev.mysql.com将网页划到最下面&#xff0c;点击下载MySQL社区安装包 按照如下图片框选的进行下载 2 解压上传 下载完了之后使用WinRAR软件在Windows电脑上解压&#xff0c;选择如下包使用ftp工具上传至Linux机器最大目录下。 3 安装前检查 …

DCGAN-MNIST——使用TensorFlow 2 / Keras实现深度卷积DCGAN来生成时尚MNIST的灰度图像

DCGAN-MNIST——使用TensorFlow 2 / Keras实现深度卷积DCGAN来生成时尚MNIST的灰度图像 1. 效果图2. 原理2.1 结构指南2.2 模型结构及训练过程 3. 源码参考 这篇博客将介绍如何使用TensorFlow 2 / Keras中实现深度卷积GAN&#xff08;DCGAN&#xff09;来生成类似时尚MNIST的灰…

魔法反射--java反射进阶(实战篇)

&#x1f473;我亲爱的各位大佬们好&#x1f618;&#x1f618;&#x1f618; ♨️本篇文章记录的为 魔法反射–java反射进阶(实战篇) 相关内容&#xff0c;适合在学Java的小白,帮助新手快速上手,也适合复习中&#xff0c;面试中的大佬&#x1f649;&#x1f649;&#x1f649;…

openpose原理及安装教程(姿态识别)

OpenPose是一个基于深度学习的人体姿态估计框架,可以实时地估计人体的关键点,包括身体和手部姿势。它是由卡内基梅隆大学的研究团队开发的,已经成为了人体姿态估计领域的一个重要项目。 OpenPose的原理是基于卷积神经网络(CNN),通过对图像进行深度学习处理,可以检测出…

如何在华为OD机试中获得满分?Java实现【寻找峰值】一文详解!

✅创作者&#xff1a;陈书予 &#x1f389;个人主页&#xff1a;陈书予的个人主页 &#x1f341;陈书予的个人社区&#xff0c;欢迎你的加入: 陈书予的社区 &#x1f31f;专栏地址: Java华为OD机试真题&#xff08;2022&2023) 文章目录 1. 题目描述2. 输入描述3. 输出描述…

Aerial Vision-and-Dialog Navigation阅读报告

Aerial Vision-and-Dialog Navigation 本次报告&#xff0c;包含以下部分&#xff1a;1摘要&#xff0c;2数据集/模拟器&#xff0c;3AVDN任务&#xff0c;4模型&#xff0c;5实验结果。重点介绍第2/3部分相关主页&#xff1a;Aerial Vision-and-Dialog Navigation (google.com…

【章节2】husky + 自动检测是否有未解决的冲突 + 预检查debugger + 自动检查是否符合commit规范

在章节1中我们学习到了commit的规范、husky的安装和使用、lint-staged怎么安装以及怎么用来格式化代码。那么这篇文章我们来看看commit预处理中我们还能做哪些处理呢&#xff1f; 自然&#xff0c;我们还是要用到husky这个东西的&#xff0c;大致过程其实和章节1异曲同工&#…

不要再来问我小学、初中毕业想出去学习编程找到工作的问题了,你要做就去做,结果自己扛着就行了!

&#x1f680; 个人主页 极客小俊 ✍&#x1f3fb; 作者简介&#xff1a;web开发者、设计师、技术分享博主 &#x1f40b; 希望大家多多支持一下, 我们一起进步&#xff01;&#x1f604; &#x1f3c5; 如果文章对你有帮助的话&#xff0c;欢迎评论 &#x1f4ac;点赞&#x1…

探索Java面向对象编程的奇妙世界(五)

⭐ Object 类⭐ toString 方法⭐ 和 equals 方法⭐ super 关键字⭐ 继承树追溯⭐ 封装(encapsulation) ⭐ Object 类 Object 类基本特性 &#x1f41f; Object 类是所有类的父类&#xff0c;所有的 Java 对象都拥有 Object 类的属性和方法。 &#x1f41f; 如果在类的声明中未…

docker-compose方式安装运行Jenkins

docker-compose方式安装运行Jenkins 服务器系统&#xff1a;centos 7.6 以docker-compose 编排容器方式安装&#xff0c;当然需提前安装docker-compose环境&#xff08;见百度->docker-compose环境安装&#xff09; docker-compose.yml version: 3.1 services:jenkins:i…

WF攻击(网站指纹攻击)

网站指纹&#xff08;WF&#xff09;攻击是被动的本地攻击者通过比较用户发送和接收的数据包序列与先前记录的数据集来确定加密互联网流量的目的地。可以通过网络流量中的模式来识别Tor用户访问过的页面。因此&#xff0c;WF攻击是Tor等隐私增强技术特别关注的题。 攻击过程 该…

分布式网络通信框架(九)——RpcChannel调用过程

介绍 客户端使用RpcChannel对象来构造UserServiceRpc_Stub对象&#xff0c;并利用该对象中RpcChannel::CallMethod来进行rpc调用请求,RpcChannel完成的工作是如下rpc调用流程图的红圈部分&#xff1a; 客户端使用mprpc框架的业务代码 // calluserservice.cc #include <ios…

【算法题解】31. 翻转二叉树的递归解法

这是一道 简单 题 https://leetcode.cn/problems/invert-binary-tree/ 题目 给你一棵二叉树的根节点 r o o t root root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a; 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,7,2,9,6…