JavaScript中的变量在内存中的存储形式

本文深入解析JavaScript中变量的存储方式,区分基本类型与引用类型在内存中的不同表现。阐述了基本类型存储在栈内存,而引用类型则通过堆内存中的地址进行访问。并通过实例展示了复制行为下两者的变化差异。

JavaScript中的变量在内存中的存储形式

JavaScript的数据类型分为基本类型引用类型

基本类型是保存在栈内存中的简单数据段,它们的值都有固定的大小,保存在栈空间,通过按值访问

引用类型是保存在堆内存中的对象,值大小不固定,栈内存中存放的该对象的访问地址指向堆内存中的对象,JavaScript不允许直接访问堆内存中的位置,因此操作对象时,实际操作对象的引用

栈内存和堆内存
let a=12345
let b='syj'
let c=null
let d=undefined
let e={name:'syj',age:12}
let f=[1,2,3]

在这里插入图片描述

基本类型发生复制行为
let a=10
let b=a
b=20
console.log(a)

在这里插入图片描述
在栈内存中的数据发生复制行为时,系统会自动为新的变量分配一个新值,最后这些变量都是相互独立互不影响的

引用类型复制行为
let a = { x: 30, y: 20 }
let b = a;
b.x = 10;
console.log(a.x);

在这里插入图片描述
1.引用类型的复制,同样为新的变量b分配一个新的值,保存在栈内存中,不同的是,这个值仅仅是引用类型的一个地址指针
2.他们两个指向同一个值,也就是地址指针相同,在堆内存中访问到的具体对象实际上是同一个
3.因此改变b.x时,a.x也发生了变化,这就是引用类型的特性

总结

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值