博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS基础-连续赋值(转)
阅读量:4921 次
发布时间:2019-06-11

本文共 813 字,大约阅读时间需要 2 分钟。

引子

今天同事聊天群里发现了一道面试题(js基础),但答案基本没有几个能答对并且理解的很透彻的。

问题

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

先不说答案,可能有些人已经答错了~

错误的答案

这多简单!JS赋值运算右结合!那就分开算呗!

a = {n: 2}a.x = a

然后错误的答案就这么产生了,a.x = {n: 2}

正解

其实这道题看似简单但还是有一些绕,我依稀记得高中数学老师那句经典的口头禅!

遇到难题:画图啊!
好吧,这句话可能我会受用一辈子,同时也送给看这篇文章的同学,希望能给你们编程带来一些新的思路。

var a = {n: 1};var b = a;

这句话也是关键所在

a.x = a = {n: 2};

根据js引擎语法解析,会先去从左到右寻找有没有未声明的变量,如果有就把该变量提升至作用域顶部并声明该变量。那么恭喜js引擎他找到a.x这个属性没有声明,那么他会在{n: 1}这个内存区声明一个x属性等待赋值!

语法解析完成后,开始进行运算(ps:赋值运算),首先将a变量的指针指向了一个新的内存区{n: 2},那么a变量脱离了对内存区{n: 1}的引用关系。

但是此时{n:1 }这个内存区并没有被GC回收因为b变量的指针依然指向它。并且因为之前就声明了x属性所以该内存区

增加了X属性。那么X属性指向哪儿呢?a.x = a = {n: 2}它的返回值就是{n: 2}的内存区。

如下图:

 

那么根据图上可得:

a.x 不存在,故: => undefined(ps:因为JS的缺陷这里应当报个错啥的~ Undefind reference)
b.x => {n: 2}

 

转载于:https://www.cnblogs.com/ganiner/p/11510041.html

你可能感兴趣的文章
B. Mike and Feet Codeforces Round #305 (Div. 1) (并查集)
查看>>
学习Python遇到的那些坑
查看>>
目录大纲
查看>>
Configure Database Mirroring
查看>>
Angular 学习笔记(三)
查看>>
哈尔滨理工大学2016新生赛H题
查看>>
Android开发EditText属性
查看>>
String StringBuffer StringBuilder
查看>>
ZBrush中Flatten展平笔刷介绍
查看>>
深度学习的代码框架
查看>>
2017年06月30号课堂笔记
查看>>
浏览器兼容问题
查看>>
实时的.NET程序错误监控产品Exceptionless开源了
查看>>
PAT 甲级 1104 sum of Number Segments
查看>>
oracle表空间创建与用户授权
查看>>
使用用Generic.xaml加载默认的主题资源
查看>>
JavaScript高级编程——Array数组迭代(every()、filter()、foreach()、map()、some(),归并(reduce() 和reduceRight() ))...
查看>>
poj 3070 Fibonacci 矩阵快速幂
查看>>
网桥知识点学习
查看>>
Android动态改变工程依赖
查看>>