ES6个人笔记记录——WeakMap

与Map两点不同
1.WeakMap只接受对象作为键名(null除外),不接受其他类型的值作为键名
2.WeakMap设计的目的在于,有时我们想在某个对象上面存放一些数据,但是这会形成对这个对象的引用

const wm1 = new WeakMap();
// 使用set
const key = {foo : 1};
wm1.set(key , 2);
console.log(wm1.get(key));

// 也接受数组
const [k1 , k2] = [[1,3,5],[2,4,6]];
const wm2 = new WeakMap([[k1 , 'foo'] , [k2 , 'bar']]);
console.log(wm2.get(k2));

只要外部的引用消失,WeakMap内部的引用就会自动被垃圾回收清除
有了WeakMap,解决内存泄露会简单

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值