面试题每日一练,测测你对JavaScript WeakMap 和数组方法的理解

2024-08-28 09:12

本文主要是介绍面试题每日一练,测测你对JavaScript WeakMap 和数组方法的理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

98dfdb456f2b1c1724c769030ca0b520.png

今天的挑战题目涉及到JavaScript中的 WeakMap、数组方法 mapreduce,以及对对象引用的管理。让我们一步步解析这段代码,看看它会输出什么以及为什么。

代码解析

首先,代码创建了一个 WeakMap 实例:

const weakMap = new WeakMap();

WeakMap 是一个键必须是对象的特殊类型的 Map,其中的键是弱引用,这意味着如果没有其他引用指向这些对象,垃圾回收机制可以自动回收它们。

接下来,代码使用 map 方法创建了一个包含对象的数组 arr

const arr = [1, 2, 3].map(n => ({ n }));
  • [1, 2, 3].map(n => ({ n })) 创建了一个新数组,其中每个元素都是一个对象,形如 { n: 1 }{ n: 2 }{ n: 3 }

然后,代码通过 forEach 方法将这些对象作为键添加到 WeakMap 中,并将对应的值设置为 obj.n * 2

arr.forEach(obj => weakMap.set(obj, obj.n * 2));
  • 这一步操作后,weakMap 中存储了三组键值对:{ n: 1 } => 2{ n: 2 } => 4{ n: 3 } => 6

接下来,代码从数组 arr 中移除了最后一个元素:

arr.pop(); // Remove the last element
  • 这行代码将数组 arr 的最后一个元素 { n: 3 } 移除。因为 WeakMap 中的键是弱引用,所以如果没有其他地方引用这个对象,它可能会被垃圾回收,从而也会从 WeakMap 中消失。

然后,代码使用 reduce 方法计算剩余对象在 WeakMap 中对应值的和:

const result = arr.reduce((acc, obj) => acc + weakMap.get(obj), 0);
  • reduce 方法遍历 arr 中剩下的两个对象 { n: 1 }{ n: 2 },并从 WeakMap 中获取它们的值,分别是 24,然后将它们相加。

输出结果

根据上述逻辑,最终的 result 值是 2 + 4 = 6。因此,console.log(result) 的输出是:

console.log(result); // 输出 6

结束

这道题目展示了 WeakMap 如何与数组操作结合使用。通过 WeakMap 的弱引用特性,删除数组中的对象元素会影响 WeakMap 中的键值对的存在。当最后一个元素被 pop 移除后,reduce 仅计算剩余对象在 WeakMap 中的对应值之和。理解 WeakMap 的行为以及如何与数组方法一起使用,对于正确解答这道题目至关重要。你答对了吗?欢迎在评论区分享你的答案和想法!

每天一道面试题,帮助你提高编程技能,不断进步!记得关注哦!

这篇关于面试题每日一练,测测你对JavaScript WeakMap 和数组方法的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114342

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Java访问修饰符public、private、protected及默认访问权限详解

《Java访问修饰符public、private、protected及默认访问权限详解》:本文主要介绍Java访问修饰符public、private、protected及默认访问权限的相关资料,每... 目录前言1. public 访问修饰符特点:示例:适用场景:2. private 访问修饰符特点:示例:

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

详解Java如何向http/https接口发出请求

《详解Java如何向http/https接口发出请求》这篇文章主要为大家详细介绍了Java如何实现向http/https接口发出请求,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 用Java发送web请求所用到的包都在java.net下,在具体使用时可以用如下代码,你可以把它封装成一

Window Server2016加入AD域的方法步骤

《WindowServer2016加入AD域的方法步骤》:本文主要介绍WindowServer2016加入AD域的方法步骤,包括配置DNS、检测ping通、更改计算机域、输入账号密码、重启服务... 目录一、 准备条件二、配置ServerB加入ServerA的AD域(test.ly)三、查看加入AD域后的变

Window Server2016 AD域的创建的方法步骤

《WindowServer2016AD域的创建的方法步骤》本文主要介绍了WindowServer2016AD域的创建的方法步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、准备条件二、在ServerA服务器中常见AD域管理器:三、创建AD域,域地址为“test.ly”