大前端JS篇之搞懂【WeakSet】
和Set一样,WeakSet也是es6新增的一种数据结构,那么它和Set有什么区别呢?
WeakSet对比Set主要是两个区别:
- WeakSet只能放置对象,不能是其他任何类型
- WeakSet里面的保存的都是对对象的弱引用
这里我们理解下什么叫对对象的弱引用,也就是说js的垃圾回收机制不会考虑WeakSet里面的对象,如果里面的对象在外面没有被引用,垃圾回收机制会回收该对象,不会考虑这些对象是否存在于WeakSet中。这就使得我们可以利用WeakSet来存放一些临时对象,而不用考虑后面这些对象如果不用了忘记清空产生内存泄漏的问题
WeakSet有三个方法:
- WeakSet.prototype.add(value):添加对象
- WeakSet.prototype.delete(value): 删除对象
- WeakSet.prototype.has(value):判断某个对象是否存在
const wset = new WeakSet()
const a = {}
const b= {}
wset.add(a)
wset.add(b)
wset.delete(a)
wset.has(b)
注意的是WeakSet没有size属性和forEach方法,没法进行遍历,因为保存的都是对象的弱引用,可能何时这些对象的引用就会不存在了。
WeakSet 的一个使用场景就是用来保存dom节点,不用担心dom节点从文档中移除产生内存泄漏的问题
标签:
javascript
, 大前端
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构