JavaScript 强引用和弱引用

众所周知,在JavaScript的内存管理技术中,不再被再引用的对象会被自动删除

在ES6中引入了两种新的数据结构WeakMap和WeakSet的弱引用集合,在一些极端的复杂情况下,可以更灵活的控制内存回收的方式,从而避免内存泄露的原因

//强引用
let user = { name: '小明', age: 18 }
let person = user
user = null
console.log(user) // null
console.log(person) // { name: '小明', age: 18 }

WeakMap

对比Map

  • 没有遍历操作
  • 没有size属性
  • 没有clear方法
  • key只能是对象

API

  • WeakMap.prototype.set()

  • WeakMap.prototype.get()

  • WeakMap.prototype.has()

  • WeakMap.prototype.delete()

// 弱引用
let user = { name: '小明', age: 18 }
let person = new WeakMap([[user, user]])
user = null
console.log(user) // null
console.log(person.get(user)) // undefined

应用场景

<button id="button">开启</button>
let btnStatus = '开启'
let button = document.getElementById('button')
button.onclick = () => {
    btnStatus = btnStatus == '开启' ? '关闭' : '开启'
    button.innerHTML = btnStatus
}
button.remove()
button = null
// btnStatus是只应用于button的属性,应该在button不存在时候同时进行删除,但是此时btnStatus还保留在内存中
// 假设btnStatus是一个复杂的对象呢?或者很多个没用到的复杂对象未删除呢?那将是内存泄漏

// 利用弱引用
let button = document.getElementById('button')
let wm = new WeakMap([[button, { btnStatus: '开启' }]])
button.onclick = () => {
	const data = wm.get(button) // 弱引用
    data.btnStatus = data.btnStatus == '开启' ? '关闭' : '开启'
    button.innerHTML = data.btnStatus
}
button.remove()
button = null 
wm.get(button) // undefined
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在TypeScript中,引用类型被分为三种主要类别:强引用、软引用(或弱引用)和循环引用。 1. **强引用 (Strong Reference)**: - 强引用是最常见的引用类型,当你直接赋值给一个变量时,就创建了强引用。对象在强引用的作用域内不会被垃圾回收,即使没有其他引用指向它,直到该强引用被置为`null`或删除。 - 强引用不会触发垃圾回收,因此如果你不希望对象被意外地释放,通常使用强引用。 2. **弱引用 (Weak Reference)**或**软引用 (Soft Reference)**: - 弱引用不同于强引用,它们不会阻止垃圾回收器收集对象。即使所有强引用都被删除,弱引用的对象仍然存在,但只有当垃圾回收器运行且没有其他强引用时,这些对象才会被回收。 - 弱引用主要用于那些不需要立即释放但又不想阻止其被垃圾回收的情况,比如定时器回调或者异步操作中的回调函数。 3. **循环引用 (Cycle Reference)**: - 当两个或多个对象相互持有对方的引用,形成一个循环引用时,JavaScript默认的垃圾回收机制(标记-清除或引用计数)会遇到问题,因为它们无法确定哪些对象不再被引用。 - 在TypeScript中,循环引用可能会导致内存泄漏,因为垃圾回收器无法正确地识别无用对象。避免循环引用的最佳实践是只在绝对必要时使用,比如使用第三方库提供的专门处理循环引用的工具(如`weak-ref`或`@types/weak-ref`)。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值