一道js赋值运算的面试题

先来看一下题目:

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

储备知识:

  • 优先级从高(20)到低(1)排列
优先级运算类型关联性运算符
20成员访问从左到右.
3赋值从右到左=
  • 关联性

a OP b OP c;

左关联(左到右)相当于把左边的子表达式加上小括号(a OP b) OP c,右关联(右到左)相当于a OP (b OP c)。

譬如:赋值运算符是右关联的,a = b = 5;

结果 a 和 b 的值都会成为5。这是因为赋值运算符的返回结果就是赋值运算符右边的那个值,具体过程是:b被赋值为5,然后a也被赋值为 b=5 的返回值,也就是5。

这下你知道答案了吗?

 console.log(a.x);  // undefined
 console.log(b);  // {n:1,x:{n:2}}

分析过程:

  1. 首先将值{n:1}赋值给a,再将a赋值给b,此时变量ab存储的都是指向同一个值{n:1}的内存地址(假定是AAAFFF000)
  2. a.x由于.运算符优先级高,所以先给{n:1}声明了一个x属性,现在的a指的是{n:1,x:undefined}
  3. 创建一个新的值{n:2}(假定是AAAFFF111),赋值给a.x,那么(AAAFFF000)中存储的值就是{n:1,x:{n:2}}
  4. {n:2}赋值给a
  5. 整理一下:
地址存储的值对应的对象
AAAFFF000{n:1,x:{n:2}}b , 原来的a
AAAFFF111{n:2}a
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值