ES6新增数据结构WeakSet的用法详解
程序员文章站
2023-02-23 23:40:33
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的用法详解,希望对大家有所帮助
上一篇: js实现图片上传预览原理分析
下一篇: JQuery EasyUI的一些常用组件