• JS基础-连续赋值(转)


    引子

    今天同事聊天群里发现了一道面试题(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}

    转自:http://sfau.lt/b5JI4r

    每天进步一点,遇见更好的你!
  • 相关阅读:
    AJAX传输图片文件
    和内嵌的iframe进行通讯
    ts的特殊数据类型
    Angular RxJs:针对异步数据流编程工具
    Angular路由使用
    RBAC基于角色的权限管理模型
    Java中的实体类--Serializable接口、transient 关键字
    字符串问题----将整数字符串转换成整数值
    字符串问题----判断两个字符串是否互为旋转词
    字符串问题----去掉字符串中连续出现K个0的子串
  • 原文地址:https://www.cnblogs.com/ganiner/p/11510041.html
Copyright © 2020-2023  润新知