为了账号安全,请及时绑定邮箱和手机立即绑定

js笔记二十八之内存释放与作用域销毁

标签:
JavaScript

堆内存

对象数据类型或者函数数据类型在定义的时候首相都会开辟一个堆内存
堆内存有一个引用地址,如果外面有变量等知道了这个地址,那么这个地址就是被占用了,就不能被销毁了

var obj1 = {name:"lilei"};var obj2 = obj2;// null: 空对象指针// 我们想要让堆内存释放/销毁,只需要把所有引用它的变量赋值为null即可,// 如果当前的堆内存没有任何东西被占用,那么浏览器会在空闲的时候把它销毁obj1 = null;
obj2 = null;

栈内存

  1. 全局作用域
    只有当页面关闭的时候全局作用域才会销毁

  2. 私有作用域(只有函数执行会产生私有作用域)
    一般情况下,函数执行会形成一个新的私有作用域,当私有作用域中的代码执行完成后,当前作用域都会主动的释放和销毁
    特殊情况:
    当前私有作用域中的部分内存被作用域外的东西占用了,那么当前的这个作用域就不能销毁了

// 函数执行返回了一个引用数据类型的值, 并且在函数的外面被一个其他的东西给接收了,// 这种情况下一般形成的私有作用域都不会被销毁function fn(){    var num = 100;    return function (){
        
    }
}var f = fn(); // fn执行形成的这个私有作用域就不能再销毁了
<!-- 在一个私有作用域中给dom元素的时间绑定方法, 一般情况下我们的私有作用域不销毁 --><div id="box"></div><script>
 var oBox = document.getElementById("box");
 ~function(){
     oBox. = function(){
         
     }
 }(); // 当前自执行函数形成的私有作用域也不销毁</script>
// 下述情况属于不立即销毁 -> fn返回的函数没有别其他的东西占用, 但是还需要执行一次呢// 所以暂时不销毁, 当返回的值执行完成后, 浏览器会在空闲的时候把它销毁了function fn(){    var num = 100;    return function () {
        
    }
};
fn()(); // 首先执行fn, 返回一个小函数对应的内存地址, 然后紧接着让返回的小函数再执行

++ i 和 i ++
都是自身累加1, 在和其他的值进行运算的时候有区别的
i ++ :先拿i的值进行运算, 运算完成本身再+1
++ i :先本身累加1 ,然后拿累加完成的结果去运算

作用域练习题

function fn(){    var i = 10;    return function(n){        console.log(n + (++i));
    }
}var f = fn();
f(10); // 21f(20); // 32fn()(10); // 21fn()(20); // 31
function fn(i){    return function(n){        console.log(n + i++);
    }
}var f = fn(13);
fn(12); // 25fn(14); // 28fn(15)(12); // 27fn(16)(13); // 29



作者:uplyw
链接:https://www.jianshu.com/p/c5ce40412dda


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消