内存释放
2017-07-30 本文已影响19人
McDu
- 让对象等于 null (空对象指针),可以不占用堆内存,堆内存不被变量占用时,可以释放(浏览器在它空闲的时候回收)。
- 对于栈内存:全局作用域只有页面关闭时销毁,私有作用域(对于 ES5,只有函数执行时产生私有作用域),当私有作用域中的代码执行完成后,一般情况下会进行释放和销毁。(执行一次,销毁一次),但当私有作用中的部分内容被作用域外的变量占用了,那么当前的作用域就不能被销毁了。比如:
- 函数执行返回了一个引用类型的值,并且在函数外部被一个变量接收,这种情况一般不被销毁。(销毁原理在于堆内存是否被占用)
- 自执行函数形成的私有作用域也不销毁。
- 在一个私有作用域中给 DOM 元素的事件绑定事件,这个私有作用域中事件被 DOM 属性占用,也不销毁。
- 当函数返回函数,没有被其他变量接收,不立即销毁,当返回的值完成后,浏览器在空闲时销毁。
function fn(){
return function (){}
}
fn()(); // 不立即销毁
var test = fn() // 有返回值被占用,不销毁
function fn(){
var i = 10;
return function (n){
console.log(n + (++i))
}
}
var f = fn();
f(10); // 10 + 11 = 21
f(20); // 20 + 12 = 32 内存未释放
fn()(10); // 10 + 11 = 21
fn()(20); // 20 + 11 = 31
var num = 20 ;
var obj = {
num:30,
fn:(function(num){
this.num *= 3;
num += 15;
var num = 45;
return function(){
this.num *= 4;
console.log(this.num)
num += 20;
console.log(num);
}
})(num)}
var fn = obj.fn;
fn(); // 240 65
obj.fn() // 120 85