原始类型、引用类型的 js 变量赋值的区别

文章解释了JavaScript中原始类型和引用类型在内存分配上的差异,指出简单变量占用独立空间,而引用类型可能共享内存地址。通过实例展示了变量赋值如何影响内存中的对象状态。

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

// 对于原始类型的值(如数字、字符串、布尔值等),每个变量通常会在栈内存中占据一个独立的空间,即使它们具有相同的值,它们的内存地址也可能不同。而对于引用类型的值,变量可能共享相同的内存地址,这取决于它们是如何被赋值的。

// 简单变量(原始类型)相当于 1个 人
// 复杂对象(引用类型) 相当于一辆车

//简单变量指向一个人,但人是可以是很多一样属性的人。 a = 1; b=1; 
// 数字(原始类型)通常会被存储在栈内存中,并且当两个变量被赋予相同的原始值时,它们会存储相同的值,但内存中的地址通常是不同的。

//引用类型
// 指向一辆车时候,车里的成员变了。另一个指向这个车的引用的成员也就变了。
 

// 对于原始类型的值(如数字、字符串、布尔值等),每个变量通常会在栈内存中占据一个独立的空间,即使它们具有相同的值,它们的内存地址也可能不同。而对于引用类型的值,变量可能共享相同的内存地址,这取决于它们是如何被赋值的。

// 简单变量(原始类型)相当于 1个 人
// 复杂对象(引用类型) 相当于一辆车

//简单变量指向一个人,但人是可以是很多一样属性的人。 a = 1; b=1; 
// 数字(原始类型)通常会被存储在栈内存中,并且当两个变量被赋予相同的原始值时,它们会存储相同的值,但内存中的地址通常是不同的。

//引用类型
// 指向一辆车时候,车里的成员变了。另一个指向这个车的引用的成员也就变了。


var arr={"a":1}

var mynum=arr.a;
console.log(mynum);//1

arr.a=888; //指向简单类型,原来arr.a的1的引用被删除,但1上面还有mynum的引用
console.log(mynum);//1





var arr2={"person":{"age":10}}
var newobj=arr2.person;
console.log(newobj);//{age: 10}

arr2.person={"haha":99};//指向新对象,一辆新的车。原来的那辆车{"age":10}还被newobj引用着

console.log(newobj);//{age: 10}





var arr3={"person":{"age":10}}
var newobj3=arr3.person;

arr3.person.age=99;

console.log(newobj3);//{age: 99},newobj3和arr3.person是同一辆车,车里的人变了,就都变了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北方的刀郎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值