创建函数
函数执行
关于堆栈内存释放问题(以谷歌webkit内核为例子)
函数执行就会形成栈内存(从内存中分配的一块空间),如果内存都不销毁释放,很容易就会导致栈内存溢出(内存爆满,电脑就卡死了),堆栈内存的释放问题是学习JS的核心知识之一
堆内存释放问题
【只要对象的引用计数器为0,这个对象就被释放了。】
// => 创建一个引用类型值,就会产生一个堆内存
// 如果当前创建的堆内存不被其它东西所占用了(浏览器会在空闲的时候,查找每一个内存的引用状况,不被占用的都会给回收释放掉),则会释放
let obj = {
name : ‘zhufeng‘
};
let oop = obj;
// 此时obj和oop都占用着对象的堆内存,想要释放堆内存,需要手动解除变量和值的关联(null:空对象指针)
obj = null;
oop = null;
栈内存释放
// => 打开浏览器形成的全局作用域是栈内存
// => 手动执行函数形成的私有作用域是栈内存
// => 基于ES6中的let/const形成的块作用域也是栈内存
// => ....
/*
* 全局栈内存:关掉页面的时候才会销毁
* 私有栈内存:
* 1.一般情况下,函数只要执行完成,形成的私有栈内存就会被销毁释放掉(排除出现无限极递归、出现死循环的模式)
* 2.但是一旦栈内存中的某个东西(一般都是堆地址)被私有作用域以外的事物给占用了,则当前私有栈内存不能立即被释放销毁(特点:私有作用域中的私有变量等信息也保留下来了)
=> 市面上认为的闭包:函数执行形成不能被释放的私有栈内存,这样的才是闭包
*/
function fn(){
//...
}
fn(); // => 函数执行形成栈内存,执行完成栈内存销毁
function X(){
return function(){
//...
}
}
let f=X(); // => f占用了X执行形成的栈内存中的一个东西(返回小函数对应的堆),则X执行形成的栈内存不能被释放了
var i = 5;
function fn(i) {
return function (n) {
console.log(n + (++i));
}
}
var f = fn(1);
f(2); // => 4
fn(3)(4); // => 8
fn(5)(6); // => 12
f(7); // => 10
console.log(i); // => 5
原文:https://www.cnblogs.com/jianjie/p/13192962.html