什么是内存泄漏?JavaScript 垃圾回收机制原理及方式有哪些?哪些操作会造成内存泄漏?

1、什么是内存泄漏? 

内存泄漏是前端开发中的一个常见问题,可能导致项目变得缓慢、不稳定甚至崩溃。内存泄漏是指不再用到的内存没有及时被释放,从而造成内存上的浪费。

2、 JavaScript 垃圾回收机制

1) 原理:

JavaScript 垃圾回收机制很简单:找出不再使用的变量,然后释放掉其占用的内存。

2)最常用的垃圾收集方式:

① 标记-清除 

对内存中所有变量加上标记,然后再去掉进入环境的变量的标记,最后就是清除那些带标记的变量并回收它们所占用的内存空间。
 

当变量进入环境时,就将这个变量标记为“进入环境”。

当变量离开环境时,这将其标记为“离开环境”。

② 引用计数

语言引擎有一张”引用表”,跟踪记录每个值被引用的次数

如果一个值的引用次数是0,就表示这个值不再用到了,因此可以将这块内存释放。

3、哪些操作会造成内存泄漏?

出现内存泄漏的情况:

① 未正确清理事件处理器 

会持有对DOM的引用,妨碍垃圾回收器释放相关的内存。
例如使用了addEventListener,那就要记得 removeEventListener

② 循环引用

当两个或多个对象相互引用时,即使你不再使用它们,它们也无法被垃圾回收。
解决方法:确保在不再需要对象时,将其引用设置为null,打破循环引用。

③ 未正确清理定时器和间隔器

原因:定时器 setInterval 或者 setTimeout 在不需要使用的时候,没有被clear,导致定时器的回调函数及其内部依赖的变量都不能被回收,这就会造成内存泄漏。


解决方法:在不再需要定时器或间隔器时,使用 clearTimeout 和 clearInterval 来清理它们

4、内存泄露排查方法: 

利用谷歌浏览器调试工具 Memory 的内存快照 Heap snapshot,找到使你内存增加的业务场景。

5、在 Vue 中有哪些注意的地方: 

虽然浏览器可以进行垃圾自动回收,但是当代码比较复杂时,垃圾回收所带来的代价较大,所以应该尽量减少垃圾回收。

① 对数组进行优化:

在清空一个数组时,最简单的方法就是给其赋值为[ ],但是与此同时会创建一个新的空对象,可以将数组的长度设置为0,以此来达到清空数组的目的。

② 对 Object 进行优化

对象尽量复用,对于不再使用的对象,就将其设置为null,尽快被回收

③ 对函数进行优化

在循环中的函数表达式,如果可以复用,尽量放在函数的外面。 

其它: 

Vue组件触发 beforeDestroy 声明钩子函数的时候,把变量置null(那些用来渲染页面的数据量大的Object、Array等;也可以全部置 null ;包括dom绑定的事件要移除、定时器要清除)

组件中使用 v-show 可能会导致 DOM 元素积累,而销毁 DOM 的核心其实还是使用v-if,尽量使用 v-if 代替v-show,同时避免不必要的DOM操作。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值