LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

ES6特殊的数据结构Set和Map

freeflydom
2024年5月28日 9:32 本文热度 955

前言

Set为ES6提供的一种新的数据结构,它类似于数组,但是成员的值都必须是唯一的,没有重复的值。

Map解决了传统意义是只能将字符串当作键的问题。


正文

Set

Set实例的创建

const s = new Set();


一系列方法

add(value) : 向集合中添加一个新元素。如果该值已经存在,则不会重复添加。

delete(value) : 删除集合中的某个值。如果值存在,则返回?true,否则返回?false。

has(value) : 检查集合中是否包含某个值,返回?true?或?false。

clear() : 清空集合中的所有元素。

size: 属性,返回集合中元素的数量。


属性方法

Set.keys():返回键名的遍历器

Set.values():返回键值的遍历器

Set.entries():返回键值对的遍历器

Set.forEach():使用回调函数遍历每个成员


代码实操:

const s = new Set();

s.add(1);

s.add(2);


console.log(s);

console.log(s.keys()); // 键名

console.log(s.values()); // 值

console.log(s.entries()); // 键值对


还可以通过传入数据的方法来初始化一个Set实例:

const s = new Set([1, 2, 3, 3]);


遍历Set对象的方法

const s = new Set([1, 2, 3, 3]);


for (let item of s) { // 专门用来遍历具有iterable(迭代器)属性的结构

    console.log(item);

}

//输出123


也可以用来遍历键值:

const s = new Set([1, 2, 3, 3]);


for (let item of s.keys()) { // 专门用来遍历具有iterable(迭代器)属性的结构

    console.log(item);

}

//输出123


WeakSet

WeakSet 结构与 Set 类似,也是不重复的值的集合。但是,它与 Set 有两个区别:


WeakSet 的成员只能是对象和 Symbol 值,而不能是其他类型的值

WeakSet 中的对象都是弱引用,即垃圾回收机制不考虑 WeakSet 对该对象的引用,也就是说,如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存,不考虑该对象还存在于 WeakSet 之中


第二点可能有点不太容易理解,通过代码实例来进行解释:

let obj = {name: '玛卡巴卡'};

let ws = new WeakSet();


ws.add(obj);

obj = null; // 如果一个对象被人为的置为null,一定会第一时间被回收掉


console.log(ws);

 

总结:

弱引用

一个对象obj存放在了其他的结构中,当后续存在其他对象引用这个对象,那么这个对象的内存就不会被回收。

一个对象obj存在了其他的结构中,当后续只存在WeakSet对它的引用,该对象的内存依然会被回收。


Map

Map实例的创建

const m = new Map(); // 可以用任意类型做key


一系列方法

set(key, value) : 添加或设置键值对。如果键已存在,则更新对应的值。

get(key) : 根据键获取值,如果键不存在则返回?undefined。

has(key) : 判断?Map?中是否存在某个键,返回布尔值。

delete(key) : 删除指定键及其对应的值,如果删除成功返回?true,否则返回?false。

clear() : 清空?Map?中的所有键值对。

size: 属性,返回?Map?中键值对的数量。


属性方法

Map.keys():返回键名的遍历器。

Map.values():返回键值的遍历器。

Map.entries():返回所有成员的遍历器。

Map.forEach():遍历 Map 的所有成员。


代码:

const m = new Map(); // 可以用任意类型做key

const o = {age: 18};

m.set(o, [1, 2, 3]);


console.log(m);

console.log(m.keys());

console.log(m.values());

console.log(m.entries());

 

代码:

const m = new Map(); // 可以用任意类型做key

const o = {age: 18};

m.set(o, [1, 2, 3]);


m.delete(o);

console.log(m.get(o));

console.log(m.has(o));

//输出undefined false


WeakMap

WeakMap结构与Map结构类似,也是用于生成键值对的集合,但是WeakMap与Map的区别有两点:


WeakMap只接受对象(null除外)和?Symbol 值作为键名,不接受其他类型的值作为键名。

WeakMap的键名所指向的对象,不计入垃圾回收机制。


WeakMap的专用场合就是,它的键所对应的对象,可能会在将来消失。WeakMap 结构有助于防止内存泄漏。

注意,WeakMap 弱引用的只是键名,而不是键值,键值依然是正常引用。


作者:椰汁33

链接:https://juejin.cn/post/7372914724512989211

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。



该文章在 2024/5/28 9:32:12 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved