连续赋值(从堆栈角度解析) a.x = a = {n:2}

连续赋值

今天看到一个面试题,一直想把这个题目解析更加直观化,就跟看小人书一样,看图就能明白其中的原理,所以用PPT做了几张图。

var a = {n: 1}
var b = a;
a.x = a = {n: 2}
console.log(a.x);
console.log(b.x)

这块最难理解的就是这块

a.x = a = {n: 2}

接下来我们从以下几点分析以下:

  1. 运算符优先级;
    我们知道运算符的优先级决定了表达式中运算执行的先后顺序,优先级高的运算符最先被执行。
    赋值运算顺序是从右往左的,不过由于“.”是优先级最高的运算符,所以这行代码先“计算”了a.x;
优先级运算类型关联性运算符
19成员访问从左到右.
3赋值从右到左… = …

链接: 运算符优先级

  1. 堆栈图来看怎么赋值操作的;
    var a={n:1}; a指向了堆内存中的对象{n:1}, var b=a; a赋予给b的时候传的是栈中的地址(相当于新建了一个不同名“指针”) ,而不是堆内存中的对象。
    在这里插入图片描述
    a.x = a = {n: 2} ;前面说了“.”的优先级大于赋值运算符的优先级,所以先来看a.x;a.x实际上是未定义的;
    在这里插入图片描述
    再来看赋值运算符的从右向左解析;a = {n : 2},a被从新赋值,指向了一个新对象,而此时a.x已经先行执行完,其实指是{ n:1,x: undefined } 这个对象,接下来看左边的等号,这个对象的x值 = 等号右边计算的结果(a={n:2},所以此时b的值通过箭头可以看出等于{n:1,x:{n:2}},a的值指向新对象{n:2}
    在这里插入图片描述

以上如有出入,请多指正~~~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值