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

  • 相关阅读:
    DataFrame中的isin查询使用
    C++多线程学习06 利用RAII
    软件测试工作的难点是什么?针对难点怎么做?
    拆分代码 + 动态加载 + 预加载,减少首屏资源,提升首屏性能及应用体验
    想把iPad作为扩展屏,确发现macOS monterey随航功能不见了
    高性能网络编程 - 关于单台服务器并发TCP连接数理论值的讨论
    【C基础篇】算法、数据类型、运算符与表达式、常见输入出函数
    数据集笔记:Beijing-BRT-dataset
    猿创征文|vue中使用Axios最佳实践
    2022 前端面试题
  • 原文地址:https://blog.csdn.net/qq_38290251/article/details/117991756