前端提高篇(八)JS进阶6内存管理之堆和栈(1)

本文解释了JavaScript中变量在栈和堆上的存储原理,重点介绍了简单变量与复杂对象的区别。同时提供了面试准备建议,强调了算法在前端面试中的重要性,尤其是对于基础扎实者。
摘要由CSDN通过智能技术生成

var b = a = 1;

console.log(‘a:’+a+’ b:'+b); // a:1 b:1

a = {n:1};

a.x = a = {n:2};

console.log('a.x: '+a.x + ’ a: '+ a);

在这里插入图片描述

原理


栈:系统分配,物理内存连续

堆:动态分配,物理地址不连续,程序自行维护

1.如果定义一个简单变量,var x = 1;,系统会为这个变量在栈中指定一个位置存放(指针),这个空间直接存放变量的值

2.如果定义一个复杂变量,如对象,var x = {n : 1};,系统会将值存储在堆中,存储的地址放在栈中;

因此,当获取复杂变量的值时,先在栈中获取其在堆的地址,再从堆里找到具体的值

解释


var b = a = 1;

在这里插入图片描述

a.x = a = {n:2};

var a = {n:1};

a.x = a = {n:2};

一开始定义了a,是一个复杂变量

在这里插入图片描述

后来修改了这个变量,添加了a.x,此时0xA0001中的a新增新的属性,但值还未定,为undefined;

在这里插入图片描述

然后计算后部分a={n:2},由于是新的一个变量,在堆中开辟了一个新的地方存放(0xF0005),a存放的地址也就修改了,指向新的地址

在这里插入图片描述

此时a中的值就变成了{n:2},a.x也就undefined了

跳槽是每个人的职业生涯中都要经历的过程,不论你是搜索到的这篇文章还是无意中浏览到的这篇文章,希望你没有白白浪费停留在这里的时间,能给你接下来或者以后的笔试面试带来一些帮助。

也许是互联网未来10年中最好的一年。WINTER IS COMING。但是如果你不真正的自己去尝试尝试,你永远不知道市面上的行情如何。这次找工作下来,我自身感觉市场并没有那么可怕,也拿到了几个大厂的offer。在此进行一个总结,给自己,也希望能帮助到需要的同学。

面试准备

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

面试准备根据每个人掌握的知识不同,准备的时间也不一样。现在对于前端岗位,以前也许不是很重视算法这块,但是现在很多公司也都会考。建议大家平时有空的时候多刷刷leetcode。算法的准备时间比较长,是一个长期的过程。需要在掌握了大部分前端基础知识的情况下,再有针对性的去复习算法。面试的时候算法能做出来肯定加分,但做不出来也不会一票否决,面试官也会给你提供一些思路。

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值