首页技术文章正文

什么是内存泄漏?哪些情况造成内存泄露?

更新时间:2021-10-14 来源:黑马程序员 浏览量:

IT培训班

什么是内存泄漏?

内存泄漏指任何对象在不再拥有或需要它之后却仍然存在。JavaScript中的内存泄漏大部分是由不合理的引用导致的。

哪些操作会造成内存泄漏?

下面我们介绍几种常见的造成内存泄露的情况

1、意外声明全局变量是最常见也最容易修复的内存泄漏问题,比如:

function fn() {
    name = '张三';
}

解释器在解释上面的函数时,会把name当做全局变量,即window.name = '张三'。只要window对象没有被清理,那么name属性和属性值将一直存在,造成内存泄露。

解决方法:

(1)只要在变量声明前面加上var、let或const关键字即可,这样变量就会在函数执行完毕后离开作用域。

(2)使用this关键字

function fn() {
    this.name = '张三';
}

(3)可以在 JavaScript 文件开头添加 “use strict”,使用严格模式。这样在严格模式下解析 JavaScript 可以防止意外的全局变量

(4)在使用完之后,对其赋值为null或者重新分配

2、 定时器导致的泄露

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

上面的代码中,只要定时器一直运行,回调函数中引用的name就会一直占用内存。

3、闭包、控制台日志、循环(在两个对象彼此引用且彼此保留时,就会产生一个循环),下面我们看一个JavaScript闭包导致的内训泄露例子

let fun = function() {
    let name = '张三';
    return function() {
        return name;
    };
};

调用fun()会导致分配给name的内存被泄漏。以上代码执行后创建了一个内部闭包,只要返回的函数存在就不能清理name,因为闭包一直在引用着它。



猜你喜欢

JavaScript中let和var和const有什么区别?

v-show和v-if有什么区别?

什么是闭包函数?如何实现?

分享到:
在线咨询 我要报名
和我们在线交谈!