今天同事聊天群里发现了一道面试题(js基础),但答案基本没有几个能答对而且理解的很透彻的。面试
var a = {n: 1}; var b = a; a.x = a = {n: 2}; console.log(a.x); console.log(b.x);
先不说答案,可能有些人已经答错了~编程
这多简单!JS赋值运算右结合!那就分开算呗!spa
a = {n: 2} a.x = a
而后错误的答案就这么产生了,a.x = {n: 2}指针
其实这道题看似简单但仍是有一些绕,我依稀记得高中数学老师那句经典的口头禅!
遇到难题:画图啊!
好吧,这句话可能我会受用一生,同时也送给看这篇文章的同窗,但愿能给大家编程带来一些新的思路。code
var a = {n: 1}; var b = a;
画图blog
这句话也是关键所在图片
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}