javascript中变量与栈、堆的关系详解


一、数据类型

变量的值的类型分为基本类型和引用类型。基本类型有字符型,数值型,null,undefined,布尔型。引用类型有对象,数组,函数,symbol类型。
内存分为栈区和堆区,所有定义的变量都储存在内存中。
栈区内存有限只能储存大小固定的基本类型。
堆区不限内存可以储存大小不固定引用类型。

二、栈和堆

这段代码的执行过程是怎样的?

let name="小红";
let age={};

首先执行器读取到let关键字之后便在栈区开辟了内存空间并把它命名为name。之后根据储存值的类型决定后续的流程,如果是基本类型则直接把值存入内存空间中。如果是引用类型则会在堆区中开辟一个内存空间并把它的地址存入到栈区的空间里即age中存的其实是堆的地址。
请添加图片描述

三、变量复制

let name="小红";
let name1=123;
name1=name;
name1=666;
consloe.log(name)//打印结果为小红
const a={};
const b=a;
b.name="小红";
console.log(a.name)//打印结果为小红

如果是基本类型则先把变量name1中储存的值先给销毁再把name的值复制一份存入name1的变量中。所以哪怕进行复制操作这两个变量依旧是两个存储空间所以互不干扰。
如果是引用类型则因为占用内存较大所以不会复制自己,而是把栈区储存的地址复制一份存入b变量中。所以这俩个变量储存的地址是一样的都指向一个对象所以会互相干扰。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript,局部变量是在函数内部声明的变量,其作用域仅限于该函数内部。当在函数内部声明一个局部变量时,JavaScript会在函数执行前对整个函数进行分析,并将变量声明提升到函数的顶部。这意味着无论在函数的哪个位置声明变量,效果都等同于在函数顶部声明变量。\[1\] 例如,在一个函数内部声明一个变量,并在该变量之前尝试访问它,结果会是undefined。这是因为在函数执行前,变量声明被提升到函数的顶部,但变量的赋值操作仍然在原来的位置。\[2\] 另外,如果在函数内部声明了一个与全局变量同名的局部变量,那么在函数内部访问该变量时,会优先使用局部变量的值。而在函数外部访问该变量时,仍然使用全局变量的值。\[3\] 总结来说,JavaScript的局部变量具有函数作用域,只在函数内部有效,并且在函数执行前会对变量声明进行提升。 #### 引用[.reference_title] - *1* *2* [JavaScript全局变量与局部变量](https://blog.csdn.net/weixin_46349935/article/details/126923337)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [JS全局、局部变量详解](https://blog.csdn.net/qq_45835014/article/details/115406983)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值