JS中按值访问与按引用访问,以及函数参数的按值传递

今天看JavaScript高级程序设计时,发现的一些问题与总结

JS中分为基本类型与引用类型,他们之间的复制操作并不一样

按值访问

例如

let a = 1
let b = a   
//b的值为1,按值访问
console.log(b)    //1

这只是在栈空间中复制了一份1,给b。也就是新创建了b,其值为a的值,也就是1,除此之外,这两个变量再无关系。这种变量保存为原始值如果对其访问叫做按值访问。

按引用访问

let bun = { name: 'jerry', age: 18 }
let jerry = bun
console.log(jerry.age);   //18
jerry.age = 22
console.log(jerry.age);   //22

JavaScript不允许直接访问内存位置,因此也就不能直接操作对象所在的内存空间。为此,保存引用值的变量是按值引用的访问的        ——《JavaScript高级程序设计》第四章

这些知识相信大家都耳熟能详了。让我发现知识不足的是下面这个例子

思考

let fn = function (obj) {
  obj.age = 18
  obj = new Object()
  obj.age = 22
}
let jerry = {}
fn(jerry)
console.log(jerry);   //{ age: 18 }

按照我以往的理解,jerry应该是{age:22}才对啊,这是什么情况呢

函数参数的按值传递

ECMAScript中所有函数的参数都是按值传递的。什么是按值传递?上面已经介绍过,是一个复制的过程,复制完之后并无关系,只是他们的值一样罢了。那么放到这个例子里来。把对象jerry传过去,复制给了形参obj,此时obj确实是和jerry公用一个地址,所以obj的修改能改到jerry上。但是当obj指向的新的地址后,jerry并不受影响,obj只是一个函数里的变量,obj要是指向的地址改变了,就真的和jerry一点关系都没有了,再怎么修改和jerry也没有关系了。所以函数传参并不是真的把jerry传过去,并不是obj就是jerry,jerry就是obj,他们真的是两个变量。

以上是看书时的总结,如有错误欢迎指出

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值