IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> js var a = {n:1} var b = a a.x = a = {n:2} console.log(a.x) console.log(b.x) -> 正文阅读

[游戏开发]js var a = {n:1} var b = a a.x = a = {n:2} console.log(a.x) console.log(b.x)

js中很经典的一道题,特此记录一下

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

输出结果为: undefined, {n: 2}

为什么呢?接下来我们来分析一下。

1、首先我们要知道,b = a 是浅拷贝,所以在堆栈中引用的是一个对象地址,b和a指向同一个对象:
在这里插入图片描述

赋值操作是从右向左进行

 var a = 1, b = 2, c = 3;
 a = b = c;

最后的a,b,c都是3。

JavaScript 总是严格按照从左至右的顺序来计算表达式

a.x是表达式

表达式从左往右执行,所以先执行 a.x,其结果是一个“引用”,暂且称为 $p,这里面存有一些信息,比如说这个变量a ({n: 1, x: undefined})

先获取等号左侧的a.x,但a.x并不存在,于是JS为(堆内存中的)对象创建一个新成员x,这个成员的初始值为undefined。那么此时:
在这里插入图片描述

接下来执行赋值操作,从右向左进行, 先执行 a = {n: 2}; 那么a有了一个新的值,但是b的值不变:
在这里插入图片描述

在这里插入图片描述
再执行 a.x = a。等号右侧的a是最新的{n: 2}, 等号左侧是$p(虽然a变了,但是$p中保存的那个a的信息是不会变的,因为那是一个“运算结果”,仍然是{n: 1, x: undefined},和b的值一样),那么将刚刚这个新的对象a的堆内存指针,赋值给了$p(上面说了$p是a.x返回的结果),那么这个$p就指向了最新的a也就是{n: 2},也就是说x便等于了新的对象a。

在这里插入图片描述
这就是最终的值,所以 a.x 值为 undefined,b.x值为 {n: 2}

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-03-10 22:58:11  更:2022-03-10 22:58:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 15:59:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码