js中的内存溢出和内存泄漏

内存溢出

内存溢出是一种程序运行会出现的错误,当程序所需要的内存大于剩余内存(机器能提供给你的内存),就会抛出内存溢出的错误

var obj = {}
for (var i = 0; i < 100000000; i++) {
    obj[i] = new Array[100000000]
}

内存泄漏

占用的内存没有及时的释放从而失去控制,从而造成内存的浪费。内存泄漏多了就容易引发内存溢出。

常见的内存泄漏案例:

1、意外的全局变量

function fn() {
    var name = '张三'
    var age = 18
    address = '上海'    // 没有用var定义,这时候address是全局的
}
fn()    // 因为address会被变量提升到了全局变量,fn调用完成后address还保留在内存中

2、没有及时清除定时器

// 没有及时清理定时器
var timer = setInterval(() => {
    console.log(new Date())
}, 1000);
// clearInterval(timer) 及时清理定时器

3、没有及时清理闭包

// 函数执行完后, 函数内的局部变量没有释放, 占用内存时间会变长,容易造成内存泄露
function fun() {
    var a = 5
    function getA() {
        return a
    }
    return getA
}
var f = fun()
f() // 5
// f = null     让内部函数成为垃圾对象,释放闭包

4、没有及时清理清理dom元素的引用

var dom = document.getElementById('box')
document.body.removeChild(dom)  // dom删除后,下面依然能打印出整个div
console.log(dom)    // <div id="box">嘿嘿嘿</div>
dom = null
console.log(dom)    // 释放资源,解除引用

5、addEventListener

监听事件的解除,监听的时候addEventListener,在不监听的时候要使用removeEventListener。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值