当前位置: 首页 > news >正文

【前端面试】七、算法-迭代器和生成器

目录

1.迭代器

2.生成器


1.迭代器

  • lterator:也被称作游标Cursor,是一种设计模式。迭代器提供了一种遍历内容的方法(比如 JS 迭代器中的next),而不需要关心内部构造。
    // 迭代器的遍历const s = new Set([1,2,3,4,5])const it = s.values()// console.log(it); // SetIterator {1, 2, 3, 4, 5}const it1 = s.values()// console.log([...it1]); // [1, 2, 3, 4, 5]const it2 = s.values()for (const val of it2) {// console.log(val); // 1 2 3 4 5} let val = nullwhile(!(val = it.next()).done) {// console.log(val);// {value: 1, done: false}// {value: 2, done: false}// {value: 3, done: false}// {value: 4, done: false}// {value: 5, done: false}}/* Array.from(arrayLike, mapFn, thisArg)arrLike:想要转换成数组的伪数组对象或可迭代对象mapFn:如果指定了该参数,新数组中的每个元素会执行该回调函数thisArg:可选参数,执行回调函数 mapFn 时 this 对象 */const it3 = s.values()const arr = Array.from(Array(5), it3.next, it3).map(x => x.value) // [1, 2, 3, 4, 5]

2.生成器

Generator:生成器,也是一种设计模式,用于构造复杂对象, JS 中的生成器,用于构造迭代器。

  •         简化语法、写起来少考虑一些变量
  •         节省空间(示例中函数体不需要定义数组承载值)
  •         分散执行片段(节省单位时间的处理量),对于单线程的前端非常重要
  •         构造异步语法 
    // 生成器构造无穷斐波那契数列function* fibonacci() {let [prev, curr] = [1, 1]yield prevyield currwhile(true) {[prev, curr] = [curr, prev + curr]yield curr}}const fib = fibonacci()const fib10 = Array.from(Array(10), fib.next, fib).map(x => x.value)// console.log(fib10) // [1, 1, 2, 3, 5, 8, 13, 21, 34, 55]// Generator异步语法function request (url) {return cb => {setTimeout(() => {cb(url)}, 1000)}}function createRunner (genFunc) {const it = genFunc()function run (data) {const result = it.next(data)if (result.done) returnresult.value(run)}return run}createRunner(function* () {const res1 = yield request('url1')console.log(res1)const res2 = yield request('url2')console.log(res2)})()

http://www.lryc.cn/news/415453.html

相关文章:

  • vs+qt一些问题
  • 基于K8S配置Jenkins主从节点实例
  • 萱仔环境记录——git的安装流程
  • 品味食家巷蛋奶酪饼,感受西北美食魅力
  • 常用的图像增强操作
  • 探索TinyDB的轻量级魅力:Python中的微型数据库
  • 模型优化学习笔记—Adam算法
  • 车辆出险报告(h5)-车辆出险记录接口-车辆相关接口
  • C基础项目(学生成绩管理系统)
  • C# 设计模式之原型模式
  • 美林数据Tempo Talents | 两大资源中心,打造开放、成长型数智人才能力平台
  • IDC权威认可!工业领域最佳实践案例!
  • 未授权访问漏洞系列详解①!
  • 第1天:Python基础语法(五)
  • 【c++】用C++制作一个简易windows系统
  • 常见锁策略
  • 【机器学习】人工神经网络优化方法及正则化技术
  • Django异步请求和后台管理实战
  • 大奖放送 | AI编程达人秀视频文章征集大赛来啦!
  • 最新小猫咪PHP加密系统源码V1.4_本地API接口_带后台
  • a bag of bones
  • XLT高速线缆自动化测试系统
  • 微软AI业务最新营收数据情况(2024年7月)
  • canvas绘制表格
  • 避免溃坝的关键:渗压计在防洪管理中的作用
  • 品牌建设如何助力中小企业突破生存瓶颈?
  • 探索Python FastAPI的Annotated参数设计:提升代码的灵活性与可读性
  • ClickHouse 进阶【建表、查询优化】
  • Qt拖拽事件详解及代码实现
  • 云原生的候选应用