内存释放

2017-07-30  本文已影响19人  McDu
  1. 让对象等于 null (空对象指针),可以不占用堆内存,堆内存不被变量占用时,可以释放(浏览器在它空闲的时候回收)。
  2. 对于栈内存:全局作用域只有页面关闭时销毁,私有作用域(对于 ES5,只有函数执行时产生私有作用域),当私有作用域中的代码执行完成后,一般情况下会进行释放和销毁。(执行一次,销毁一次),但当私有作用中的部分内容被作用域外的变量占用了,那么当前的作用域就不能被销毁了。比如:
    1. 函数执行返回了一个引用类型的值,并且在函数外部被一个变量接收,这种情况一般不被销毁。(销毁原理在于堆内存是否被占用)
    2. 自执行函数形成的私有作用域也不销毁。
    3. 在一个私有作用域中给 DOM 元素的事件绑定事件,这个私有作用域中事件被 DOM 属性占用,也不销毁。
    4. 当函数返回函数,没有被其他变量接收,不立即销毁,当返回的值完成后,浏览器在空闲时销毁。
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
上一篇下一篇

猜你喜欢

热点阅读