Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Devtools 老师傅养成[7] - Memory 内存

Devtools 老师傅养成[7] - Memory 内存

作者头像
scarsu
发布于 2020-10-22 02:10:20
发布于 2020-10-22 02:10:20
1.6K00
代码可运行
举报
文章被收录于专栏:自律神仙ScarSu自律神仙ScarSu
运行总次数:0
代码可运行

本文结构

- 系列文相关

- 内存 & 内存泄漏 & GC

- 造成内存泄漏的常见原因

- 内存监控1-Task Manager 任务管理器

- 内存监控2-Devtools Performance面板

- 内存监控3-Devtools Memory面板

- 扩展

本文共计:1620字6图

预计阅读时间:4min10s

系列文相关

  • 本文基于 chrome 浏览器版本 73.0.3683.103(正式版本)总结
  • 本文目的:关于【devtools 能做什么】建立完善的知识结构,至于怎么做,请查阅官方文档;工具类知识需要实践,建议阅读本文时打开 sample[1]和 devtools 操作一遍
  • 参考 1:google developers 官方文档[2]
  • 参考 2:来自作者 Jon Kuoerman 在 FrontEndMaster 的 Mastering Chrome Developer Tools v2 课程[3]
  • 参考 3:来自 作者 Tomek Sułkowski 在 medium 的系列文章[4]
  • Devtools脑图.png[5]

内存 & 内存泄露 & GC

内存占用:

  1. allocate 分配内存(eg 声明变量
  2. 使用内存
  3. release 释放内存

内存泄漏:

  • 内存泄露-Memory Leak:内存被占用后无法被 release,且无法被垃圾回收器回收
  • 内存泄漏会引起性能问题,且时间越久越严重,因为被占用且无法回收的内存只会增加不会减少

GC 垃圾回收 Garbage Collect:

  • 浏览器收回内存。浏览器决定何时进行垃圾回收。回收期间,所有脚本执行都将暂停。因此,如果浏览器经常进行垃圾回收,脚本执行就会被频繁暂停

造成内存泄露常见原因

  • fogotten timer被遗忘的计时器:例如调用 setInterval()方法一定要加结束条件
  • Dettached HTMLElement分离的 dom 节点:在 dom 被移除后,dom 变量仍然存在

内存监控 1-Task manager 任务管理器

  • chorme 浏览器 -> task manager 任务管理器工具中,可以监控每个 tab 页的 js 内存占用大小
  • Memory 列表示原生内存。DOM 节点存储在原生内存中。如果此值正在增大,则说明正在创建 DOM 节点。
  • JavaScript Memory列表示 JS 堆。此列包含两个值。实际大小表示页面上的对象正在使用的内存量。如果此数字在增大,要么是正在创建新对象,要么是现有对象正在增长。

内存监控 2-Devtools Performance 面板

  • Performance面板记录性能时,勾选memory即可在分析结果中看到 memory 占用情况
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//示例1:正常的内存占用与GC

var x = [];

function grow() {
    for (var i = 0; i < 10000; i++) {
        document.body.appendChild(document.createElement("div"));
    }
    x.push(new Array(1000000).join("x"));
}

setInterval(grow, 100);
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//示例2:不可被GC的内存泄漏

function grow() {
    // for (var i = 0; i < 10000; i++) {
    //     document.body.appendChild(document.createElement("div"));
    // }
    // x.push(new Array(1000000).join("x"));
    var ul = document.createElement("ul");
    for (var i = 0; i < 10; i++) {
        var li = document.createElement("li");
        ul.appendChild(li);
    }
    detachedTree = ul;
}

setInterval(grow, 1000);

内存监控 3-Devtools Memory 面板

  • 如上图所示,在右侧三种内存分析模式选择一种后,即可点击左上角record开始记录内存
  1. Heap snapshot堆快照,记录当前时间点内存中页面 js 对象和 dom 节点的分配情况
  2. Allocation instrumentation on timeline按时间轴记录内存,可以选记录内存分配调用栈(可以帮助定位到具体分配内存的源码)
  3. Allocation sampling使用抽样方法记录内存分配。具有最小的性能开销,可用于长时间运行的操作。提供了由 JavaScript 执行堆栈细分的良好近似分配。
  • 左上角的垃圾桶图标Collect garbage是强制执行一次垃圾回收,内存监控的最佳实践是在监控内存前执行一次强制垃圾回收
  • 利用上述示例 2 代码,执行时间线 Memory 分析:

扩展

  • 内存相关术语[6]
  • 深入内存分析[7]

参考资料

[1]

sample: https://masteringdevtools.com/

[2]

google developers 官方文档: https://developers.google.com/web/tools/chrome-devtools/

[3]

Mastering Chrome Developer Tools v2 课程: https://frontendmasters.com/courses/chrome-dev-tools-v2

[4]

系列文章: https://medium.com/@tomsu

[5]

Devtools脑图.png: https://i.loli.net/2019/04/19/5cb95639a9f73.png

[6]

内存相关术语: https://developers.google.com/web/tools/chrome-devtools/memory-problems/memory-101

[7]

深入内存分析: https://developers.google.com/web/tools/chrome-devtools/memory-problems/heap-snapshots

- END -

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-06-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 自律神仙ScarSu 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【JS】324- JS中的内存管理(中高级前端必备)
像C语言这样的底层语言一般都有底层的内存管理接口,比如 malloc()和free()用于分配内存和释放内存。而对于JavaScript来说,会在创建变量(对象,字符串等)时分配内存,并且在不再使用它们时“自动”释放内存,这个自动释放内存的过程称为垃圾回收。因为自动垃圾回收机制的存在,让大多Javascript开发者感觉他们可以不关心内存管理,所以会在一些情况下导致内存泄漏。
pingan8787
2019/08/23
1.4K0
【JS】324- JS中的内存管理(中高级前端必备)
JS内存泄漏排查方法
内存泄漏是一个累积的过程,只有页面生命周期略长的时候才算是个问题(所谓“刷新一下满血复活”)。频繁交互能够加快累积过程,偏展示的页面很难把这样的问题暴露出来。最后,JS逻辑相对复杂才有可能出现内存问题(“bug多是因为代码量大,我自己都hold不住”),如果只是简单的表单验证提交,还没什么机会影响内存
ayqy贾杰
2019/06/12
7.7K0
JS内存泄漏排查方法
Chrome开发者工具不完全指南:(三、性能篇)
 卤煮在前面已经向大家介绍了Chrome开发者工具的一些功能面板,其中包括Elements、Network、Resources基础功能部分和Sources进阶功能部分,对于一般的网站项目来说,其实就是需要这几个面板功能就可以了(再加上console面板这个万精油)。它们的作用大多数情况下是帮助你进行功能开发的。然而在你开发应用级别的网站项目的时候,随着代码的增加,功能的增加,性能会逐渐成为你需要关注的部分。那么网站的性能问题具体是指什么呢?在卤煮看来,一个网站的性能主要关乎两项,一是加载性能、二是执行性能。第一项可以利用Network来分析,我以后会再次写一篇关于它的文章分享卤煮的提高加载速度的经验,不过在此之前,我强烈推荐你去阅读《web高性能开发指南》这本书中的十四条黄金建议,这是我阅读过的最精华的书籍之一,虽然只有短短的一百多页,但对你的帮助确实无法估量的。而第二项性能问题就体现在内存泄露上,这也是我们这篇文章探讨的问题——通过Timeline来分析你的网站内存泄露。
bear_fish
2018/09/19
7480
Chrome开发者工具不完全指南:(三、性能篇)
JS魔法堂:再识IE的内存泄露
一、前言                               IE6~8除了不遵守W3C标准和各种诡异外,我想最让人诟病的应该是内存泄露的问题了。这阵子趁项目技术调研的机会好好的再认识一回,以下内容若有纰漏请大家指正,谢谢!   目录一大坨! 二、内存泄漏到底是哪里漏了? 2.1. JS Engine Object、DOM Element 和 BOM Element 2.2. JS Engine Object的内存回收机制 2.3. DOM Element的内存回收机制 2.4. 两种泄漏
^_^肥仔John
2018/01/18
3.4K0
JS魔法堂:再识IE的内存泄露
5个常见的JavaScript内存错误
JavaScript 不提供任何内存管理操作。相反,内存由 JavaScript VM 通过内存回收过程管理,该过程称为垃圾收集。
前端小智@大迁世界
2022/06/15
1.4K0
5个常见的JavaScript内存错误
JavaScript 内存详解 & 分析指南
这些年来 JavaScript 成长飞速,生态圈日益壮大,成为了最受程序员欢迎的开发语言之一。并且现在的 JavaScript 不再局限于网页端,已经扩展到了桌面端、移动端以及服务端。
陈皮皮
2021/01/28
1.3K0
JavaScript 内存详解 & 分析指南
Chrome 浏览器垃圾回收机制与内存泄漏分析
JavaScript 引擎会通过向下移动 ESP(记录当前执行状态的指针) 来销毁该函数保存在栈中的执行上下文。
winty
2019/12/20
3.2K0
如何定位内存泄露
完整高频题库仓库地址:https://github.com/hzfe/awesome-interview
HZFEStudio
2021/10/30
2.2K0
js垃圾回收与内存泄漏
JavaScript的垃圾回收机制是一种自动化的内存管理机制,用于检测和回收不再使用的内存资源,以便重新分配给其他需要的部分。JavaScript中的垃圾回收器负责跟踪和管理内存的分配和释放,使开发人员无需手动管理内存。
can4hou6joeng4
2023/11/17
2820
node内存泄漏以及定位
之前一次偶然机会发现,react 在server渲染时,当NODE_ENV != production时,会导致内存泄漏。具体issues: https://github.com/facebook/react/issues/7406 。随着node,react同构等技术地广泛运用,node端内存泄漏等问题应该引起我们的重视。为什么node容易出现内存泄漏以及出现之后应该如何排查,下面通过一个简单的介绍以及例子来说明。
IMWeb前端团队
2019/12/04
1.1K0
node内存泄漏以及定位
浏览器的内存泄漏场景、监控以及分析
虽然前端有垃圾回收机制,但当某块无用的内存,却无法被垃圾回收机制认为是垃圾时,也就发生内存泄漏了
请叫我大苏
2020/02/13
3.6K0
浏览器的内存泄漏场景、监控以及分析
JavaScript 内存泄露的4种方式及如何避免
本文将探索常见的客户端 JavaScript 内存泄露,以及如何使用 Chrome 开发工具发现问题。
哲洛不闹
2018/09/18
4.9K0
JavaScript 内存泄露的4种方式及如何避免
Android内存泄漏分析
强引用:类似“Object obj = new Object()”这类的引用,只要强引用还存在,垃圾收集器永远不会回收掉被引用的对象。
用户1205080
2019/03/06
1.6K0
Android内存泄漏分析
JavaScript 常见的内存泄漏
JavaScript 是一种垃圾回收语言,垃圾回收语言通过周期性地检查之前被分配的内存是否可以从应用的其它部分访问来帮助开发者管理内存。内存泄露是指当一块内存不再被应用程序使用的时候,由于某种原因,这块内存没有返还给操作系统或者内存池的现象。内存泄漏可能会导致应用程序卡顿或者崩溃。
李振
2021/11/26
8630
JavaScript 常见的内存泄漏
Devtools 老师傅养成[1] - Chrome Devtools介绍
国产的所有 “双核浏览器”,都是基于 Chromium 开发的,当然 Chrome 也是基于它。
scarsu
2020/10/22
1.2K0
Devtools 老师傅养成[1] - Chrome Devtools介绍
JavaScript性能优化
内存为什么需要管理呢?当程序执行的时候需要去内存申请一片空间进行使用,如果内存不进行管理释放内存空间,那么内存很容易就会溢出。
用户3045442
2020/08/12
1.2K0
JavaScript性能优化
Devtools 老师傅养成[4] - Sources 面板
“BlackBox Script”可以在调试中忽略某些脚本(此处的 BlackBox 为动词),在 Call Stack 堆栈中会将该脚本隐藏,单步调试时也不会步入脚本中的任何函数
scarsu
2020/10/22
1.8K0
Devtools 老师傅养成[4] - Sources 面板
页面卡顿?内存泄漏?一文详解如何排查
不知道在座的各位有没有被问到过这样一个问题:如果页面卡顿,你觉得可能是什么原因造成的?有什么办法锁定原因并解决吗?
公众号@魔术师卡颂
2021/05/08
2.9K1
页面卡顿?内存泄漏?一文详解如何排查
「硬核JS」你的程序中可能存在内存泄漏
想来很多同学看到内存泄漏,内心直接会跳出两个字:闭包!!!再让你说点其它的估计就噤声了。如果你对内存泄漏的了解仅限于闭包,那真的是应该仔细看此文了,闭包可能会造成内存泄漏,但是内存泄漏并不是只有闭包,它只是内存泄漏的引子之一罢了。
用户1250838
2021/08/26
1.3K0
Devtools 老师傅养成[6] - Performance 面板
google developers 官方文档: https://developers.google.com/web/tools/chrome-devtools/
scarsu
2020/10/22
2.2K0
Devtools 老师傅养成[6] - Performance 面板
相关推荐
【JS】324- JS中的内存管理(中高级前端必备)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验