JavaScript 函数参数与实参:传递的是值还是引用?

javascript 函数参数与实参:传递的是值还是引用?

函数参数与实参之间的关系:解开 javascript 中的奥秘

最近,关于 javascript 中函数参数和实参之间的关系的问题引发了许多讨论。为了深入了解这一概念,让我们考虑一个示例:

const a = [1, 2, 3];
function test(x) {
  console.log(x === a); // true
  x = [2, 3, 4];
  console.log(a); // [1, 2, 3]
  console.log(x); // [2, 3, 4]
}
test(a);

在这个示例中,以下问题引发了困惑:

  • 为什么变量 a 没有被重写为 [2, 3, 4]?
  • 在函数执行期间,形参 x 和实参 a 之间是什么关系?

答案的根源在于 javascript 中值传递和引用传递的机制。在前面的示例中,当 x 被赋予 a 时,它并不是通过值传递,即创建一个 a 数组的副本。相反,x 接收的是指向 a 数组的引用,即保存其内存地址。

因此,当 x 被重新赋值为 [2, 3, 4] 时,它只改变了它自己的内存地址,而 a 仍然指向原来的数组。这就是为什么控制台打印 a 仍然为 [1, 2, 3],而 x 已更新为 [2, 3, 4]。

总而言之,在 javascript 中,函数参数通常接收实参值的引用,而不是值本身。这种机制允许实参在函数执行期间被修改,但更改仅反映在函数内部,而不影响外部作用域中相应变量的值。

以上就是JavaScript 函数参数与实参:传递的是值还是引用?的详细内容,更多请关注其它相关文章!