• 什么是内存泄漏?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操作。

  • 相关阅读:
    Linux知识点+命令
    web通信基础
    Java基础语法
    js实现放大镜(详细注释)
    一份面向刷题的 C++ STL 使用指南
    【Python】返回指定时间对应的时间戳
    实验九—基本统计分析(二)
    朴素贝叶斯----评论情感分析系统
    Cpp创建桌面快捷方式lnk
    leetcode 周赛——2848. 与车相交的点
  • 原文地址:https://blog.csdn.net/qq_38290251/article/details/117991756