函数执行就会形成栈内存(从内容中分配的一块空间),如果内存都不销毁释放,很容易就会导致栈内存溢出(内存爆满,电脑就卡死了)
- 堆内存释放问题
创建一个引用类型值,就会产生一个堆内存
如果当前创建的堆内存不被其他东西所占用了(浏览器会在空闲的时候,查找每一个内存的引用状况,不被占用的都会给回收释放掉),则会释放,例如:
let obj={
name:'堆内存'
}
let oop=obj;
//此时obj和oop都占用着对象的堆内存,想要释放堆内存,需要手动解除变量和值的关联(null:空对象指针)
obj=null;
oop=null;
- 栈内存释放
- 栈内存的形成:
- 打开浏览器形成的全局作用域是栈内存
- 手动执行函数形成的私有作用域是栈内存
- 基于ES6中的let/const形成的块作用域也是栈内存
- …
- 全局栈内存:关掉页面的时候才会销毁
- 私有栈内存:
- 一般情况下,函数执行完成,形成的私有栈内存就会被销毁释放掉(排除出现无限极递归、出现死循环的模式)
- 但是一旦栈内存中的某个东西(一般都是堆地址)被私有作用域以外的事物给占用了,则当前私有栈内存不能立即被释放掉销毁(特点:私有作用域中的私有变量等信息也保留下来了),简单来说:函数执行形成不能被释放的私有栈内存称为闭包
function fn(){
//....
}
fn(); //函数执行形成栈内存,执行完成栈内存销毁
function x(){
return function(){
//.....
}
}
let f=x(); //=>fn占用了x执行形成的栈内存中的一个东西(返回小函数对应的堆),则x执行形成的栈内存不能被释放了