console.log 会导致内存泄漏吗

console.log 会导致内存泄漏吗

经常看到一些文章说 console.log 会导致内存泄漏,这是真的吗?那以后是不是不能用 console.log 了?

这些说法多少有些以偏概全。先说结论:

  1. nodejs 中 console.log 不会导致内存泄漏
  2. 浏览器中使用 console.log 打印对象时,会导致内存泄漏(无论打不打开开发者工具)
  3. 少量的内存泄漏根本就不在乎,如果是循环中打印大量的对象,就要注意了

打印基本类型的数据时肯定不会造成内存泄漏。而在浏览器控制台打印对象时,由于需要保存对象的引用(以便随时查看对象的详细信息),因此表面上我们在程序中不再使用这个对象,但是控制台中还有这个对象的引用,导致对象无法被回收,从而造成内存泄漏。

html 复制代码
<body>
  <button>打印</button>

  <script>
    const btn = document.querySelector('button')
    btn.addEventListener('click', () => {
      // 大概 4MB 大小的数组
      console.log(new Array(1024 * 1024).fill(0))
    })
  </script>
</body>

上面代码中,每次点击按钮都会打印一个 4MB 大小的数组,打开浏览器任务管理器(shift + Esc),观察网页所占用的内存,

可以看到,不管打不打开浏览器开发者工具,内存都会持续增长,这就是内存泄漏。

那以后到底用不用 console.log 呢?其实很简单,开发环境用无所谓,生产环境借助打包工具自动帮助我们删除代码中的 console.log 即可。

以 vite 为例,只需要安装 terser,并在 vite.config.js 中配置 build 选项即可:

javascript 复制代码
export default {
  build: {
    minify: 'terser',
    terserOptions: {
      compress: {
        // 删除 console 语句
        drop_console: true,
        // 删除 debugger
        drop_debugger: true,
      },
    },
  },
}

不要轻视内存泄漏,但也不要害怕内存泄漏!全局变量不会被 gc 回收,某种意义上也相当于内存泄漏,那会有人因此不用全局变量吗?

所以说 console.log 导致的内存泄漏压根就不是事儿!

参考

相关推荐
华仔啊3 小时前
除了防抖和节流,还有哪些 JS 性能优化手段?
前端·javascript·vue.js
小鸡吃米…3 小时前
Python 中的并发 —— 进程池
linux·服务器·开发语言·python
小王不爱笑1323 小时前
Java 异常全解析:从原理到实战,搞定异常处理
java·开发语言
历程里程碑3 小时前
40 UDP - 2 C++实现英汉词典查询服务
linux·开发语言·数据结构·c++·ide·c#·vim
前端Hardy3 小时前
Electrobun 正式登场:仅 12MB,JS 桌面开发迎来轻量化新方案!
前端·javascript·electron
叫我一声阿雷吧4 小时前
JS 入门通关手册(20):构造函数与原型:JS 面向对象第一课
开发语言·javascript·前端开发·前端面试·构造函数·js进阶·js面向对象
2501_945423544 小时前
C++与Rust交互编程
开发语言·c++·算法
小王不爱笑1324 小时前
Java Set 集合全家桶:HashSet、LinkedHashSet、TreeSet 详解与实战
java·开发语言
早點睡3904 小时前
ReactNative项目Openharmony三方库集成实战:@react-native-ohos/react-native-image-picker
javascript·react native·react.js
code_whiter4 小时前
C++2(类与对象上篇)
开发语言·c++