欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ES6新增数据结构WeakSet的用法详解

程序员文章站 2022-05-26 08:17:16
weakset和set类似,同样是元素不重复的集合,它们的区别是weakset内的元素必须是对象,不能是其它类型。 特性: 1.元素必须是对象。 添加一个number...

weakset和set类似,同样是元素不重复的集合,它们的区别是weakset内的元素必须是对象,不能是其它类型。

特性:

1.元素必须是对象。

添加一个number类型的元素。

const ws = new weakset()
ws.add(1)

结果是报类型错误。

typeerror: invalid value used in weak set

添加一个对象。

const ws = new weakset()
var a = {p1:'1', p2:'2'}
ws.add(a)
console.log(ws.has(a));

添加ok,结果显示:

true

可以通过weakset的has方法判断一个元素是否已在集合中。

如果不需要存储元素时,可以使用delete方法删除元素。

2.弱引用,不被计入垃圾回收

添加进weakset的元素对象,weakset不会对元素对像的引用计数加1,对于被添加进weakset的元素对象,只要该元素对象没有被除weakset以外的其他对象引用,就会被垃圾回收释放,在weakset中的该元素对象自动被释放,不会出现内存泄漏。

因为这一特性,其性能要比map要高,对于存储无顺序要求的,不重复的,临时存储的场景,可以使用它。

const ws = new weakset()
var a = {p1:'1', p2:'2'}
ws.add(a)
a = null
console.log(ws.has(a));

先将对象添加到weakset中,然后将对象设成null,然后再下面的has方法判定时,结果显示,表示weakset中已经不存在该对象。

false

3.不能遍历

因为其对内部的元素对象是弱引用,随时会被垃圾回收释放掉,所以其不支持size和foreach等遍历方法。

总结

以上所述是小编给大家介绍的es6新增数据结构weakset的用法详解,希望对大家有所帮助