[JS] 让人犯晕的JavaScript变量赋值

变量赋值

本文转载自http://hellobug.github.io/blog/javascript-variable-assignment/

 

开始之前先来几个例子,确保起始点是晕的状态~ :P

例1.1

1
2
3
4
var a = "apple"; var b = a; a = "banana"; b 

按理说,b = a后,a是啥值b就应该跟着是啥值了~
但,b结果是"apple",还是一开始赋值时a的值。

例1.2

1
2
3
4
var a = {name: "apple"}; var b = a; a.name = "banana"; b.name 

这回,b又不争气的跟着a变了,b.name结果是"banana"

例1.3

1
2
3
4
var a = {name: "apple"}; var b = a; a = {name: "banana"}; b.name 

这回b又坚持自己了,b.name结果是"apple"

例1.4

1
2
3
4
var a = {count: 2}; var b = a.count; a.count = 3; b 

同样b的结果还是最开始的2,b到底是要闹哪样?!

======================开始解释的分割线==============================

其实b很无辜,这个要从ECMAScript的变量值类型说起~

类型共有两种:

  • 基本类型 (primitive values) - 包括Undefined, Null, Boolean, Number和String五种基本数据类型
  • 引用类型 (reference values) - 保存在内存中的对象们,不能直接操作,只能通过保存在变量中的地址引用对其进行操作

现在回来看第一个例子例1.1

1
var a = "apple"; 

"apple"是String类型,属于基本类型,这时值是这样储存的:

1
var b = a; 

这时a的值被copy了一份赋给了b:

所以,从此a和b井水不犯河水,各自怎么修改都不会影响对方了~

再来看第二个例子例1.2

1
var a = {name: "apple"}; 

{name: "apple"}是一个Object,属于引用类型,赋值前后值是这样存储的:

所以当a.name = "banana";时,修改的是大家共同指向的内存中的object的属性值,所以b.name的值也就跟着变了。

例1.3中,

例1.3

1
2
3
4
5
6 
var a = {name: "apple"}; var b = a; a = {name: "banana"}; // {name: "banana"} 是内存中的一个新的Object了, // a变量存储的地址也是指向这个新的Object的了,所以和b又无关了 b.name //还是"apple" 

例1.4中,

例1.4

1
2
3
4
5
6 
var a = {count: 2}; var b = a.count; // a.count是Number类型,所以值被copy给b, // 从此再怎么修改与b无关了 a.count = 3; b //还是2 

小总结,变量赋值时总是会copy一份的,如果是基本类型,copy的就是实际的值,如果是引用类型,copy的是指向Object的地址值,所以指向的还是同一个Object。


变量比较

顺手再来看看变量的比较~

例2.1

1
2
3
var a = "apple"; var b = "apple"; a == b 

这个没问题,结果肯定是true

那这个呢?

例2.2

1
2
3
var a = ["apple"]; var b = ["apple"]; a == b 

虽然俩数组长一模一样,结果还是false

其实原理还是一样,对于基本类型,比较的就是实际的值,而对于引用类型(Array也是一种Object),比较的是地址值,虽然两个数组内容是一样的,但它们在内存中是两个Object,地址是不一样,所以比较的结果是false

转载于:https://www.cnblogs.com/mjbin/p/5000151.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值