常见的内存泄漏

常见的内存泄漏

  1. 意外声明全局变量导致的内存泄漏

    意外声明全局变量是最常见的也是最容易修复的内存泄露问题,下面看一个例子

    function setName(){
    	name='小明'
    };
    

    这时候的解析器会把name当作window的属性来创建(相当于window.name=‘小明’),可想而知,只要window不被清理那么name就不会消失,这个问题也好解决,就是再变量声明前添加var、let、const关键字即可,这样变量就会在函数执行完离开作用域。

  2. 定时器导致的内存泄漏

    定时器是通过使用闭包引用了外部变量导致的内存泄露,

    let name = '小明';
    setInterval(()=>{
    console.log(name);
    },100);
    

    只要定时器一直运行,回调函数中的name就会一直存在,占用内存空间。垃圾回收程序也知道这一点,但就是不会清理外部变量。

  3. 闭包导致的内存泄漏

    直接看例子

    let setName = function(){
    	let name = '小明';
    	return function(){
    		return name;
    	};
    };
    

    当调用setName在这个函数时会导致分配给name的内存泄露,只要被返回的函数一直存在,那么name就一直会存在,不会被清理,因为闭包就一直在引用着name,假如name的内容很大,那么就会导致性能损耗。

有什么理解不到位的,还望各位大佬不吝赐教。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值