深入JavaScript 赋值后的内存分布

在阅读前,请先读下面这篇链接文章里的《二、从底层角度讲》,它能让你对JS参数传递的具体机理有一定了解。其实两者差别不大。

也可以看看这篇文章,也不错《可视化分析js的内存分配与回收》


现在开始进入正题

关键点:
  • 运算符=就是创建或修改变量在内存中的指向.
  • 初始化变量时为创建,重新赋值即为修改.

一、

例1

var a = {b: 1};   // a = {b: 1}
var c = a;        // c = {b: 1}
a = 2;            // 重新赋值a
console.log(c);   // {b: 1}

这段代码在内存中的分布:
在这里插入图片描述
然后一步一步执行代码:
(1)创建变量a指向对象{b: 1};
(2)创建变量c指向对象{b: 1};
(3)a重新指向常量区的2;
在这里插入图片描述
所以c从始至终都是指向对象{b: 1}, 所以最后输出 {b: 1}

例1.2
我们现在再分析《深入JavaScript 共享传递》中 按值传递 的例子。

var value = 1;
function foo(v) {
    v = 2;
    console.log(v); //2
}
foo(value);
console.log(value) // 1

可以将其等价替换为:

var value = 1;
function foo() {
    var v = value; // 创建变量v指向value所指向的值
    v = 2;// v重新指向另外的值
    console.log(v); //2
}
foo(value);
console.log(value) // 1,value从始至终都未改变指向.

《深入JavaScript 共享传递》中 共享传递 的例子同理。


二、

例2

var a = {b: 1};   // a = {b: 1}
var c = a;        // c = {b: 1}
a.b = 2;          // 重新赋值对象a中的属性b
console.log(c);   // {b: 2},// c也随着修改,从

前两句执行完后 在内存中的分布:
在这里插入图片描述
再执行完a.b = 2后:
在这里插入图片描述
那么a,c从始至终都未改变指向,只是b改变了而已

例2.2
我们现在再分析《深入JavaScript 共享传递》中 按值传递 的例子。

var obj = {
    value: 1
};
function foo(o) {
    o.value = 2;
    console.log(o.value); //2
}
foo(obj);
console.log(obj.value) // 2

可以将其等价替换为:

var obj = {
   value: 1
};
function foo() {
   var o = obj;
   o.value = 2;        // 变量value改变了指向,而o并未改变
   console.log(o.value); //2
}
foo(obj);
console.log(obj.value) // 2
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值