今天看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,他们真的是两个变量。
以上是看书时的总结,如有错误欢迎指出