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

本文详细介绍了JavaScript中的数据类型,包括基本类型和引用类型,并解析了内存中的栈和堆的区别。栈主要存储基本类型,而堆负责存储引用类型的对象。在变量复制过程中,对于基本类型,复制的是值;对于引用类型,复制的是引用地址。这一概念对于理解JavaScript中的变量行为至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


一、数据类型

变量的值的类型分为基本类型和引用类型。基本类型有字符型,数值型,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变量中。所以这俩个变量储存的地址是一样的都指向一个对象所以会互相干扰。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值