JS内存泄漏

1. 查询内存泄漏的方法

1. 使用快捷键 F12 或者 Ctrl+Shift+J 打开 Chrome 浏览器的「开发者工具」
2. 选择 Performance(老版为Timeline) 选项卡,在 Capture 选项中,只勾选 Memory
3. 设置完成后,点击最左边的 Record 按钮,然后就可以访问网页了。
4. 打开一个网站,例如:www.taobao.com当网页加载完成后,点击 Stop,等待分析结果。
5. 然后在 Chart View 上寻找内存急速下降的部分,查看对应的 Event Log,可以从中找到GC 的日志。

具体过程如下图所示:


2.导致内存泄漏的原因

1. 意外的全局变量

2. dom清空时,还存在引用

3. 定时器中的内存泄漏

4. 不规范地使用闭包

3.防止内存泄漏的方法

1. 减少不必要的全局变量,或者生命周期较长的对象,及时对无用的数据进行垃圾回收(即赋值为null);
2. 注意程序逻辑,避免“死循环”之类的 ;
3. 避免创建过多的对象 原则:不用了的东西要记得及时归还。
4. 减少层级过多的引用

4. 浏览器的垃圾回收机制

浏览器垃圾回收机制的方式:引用计数、标记清除
一般使用的是标记清除,因为引用计数的方法不能解决循环引用的问题

引用计数:引用类型的值被指向某个变量时,引用计数加一;同理,当引用类型的值与某个变量不再关联时,则引用计数减一;这样,当引用计数再次达到0时,就会被认为此内存不再被需要,在下次垃圾回收循环中会被释放。

标记清除:每当声明一个变量或者方法时,会被做上标记“进入环境”。当环境中的变量无法访问到这些变量的时候就会被标记为视为准备删除的变量

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值