JavaScript内嵌函数是传值还是传址

在一般编程语言中, 参数都是"传值", 假设一个C函数的原型是int Fun(int value); 当你调用这个函数时, Fun函数首先会在自己的函数栈上copy一份参数, 就是这个函数的副本, 当你在Fun外部修改value值, 并不会影响Fun内部的value. 而Javascript的内嵌函数很特殊, 如果传人是对象的话,它并不会copy一个参数副本, 所有函数公用一套参数, 所以你在函数外部修改了参数值, 函数内部也会受影响. 这就是为什么你的show函数, 它的z参数是最后一个值, 因为每一次循环, z都被更改了. 传值和传址的问题。
在 JavaScript 中,变量的传递方式是“按值传递”。这意味着当你把一个变量传递给一个函数时,实际上传递的是该变量的值,而不是它的地址。

例如:

javascript
复制
let x = 5;

function changeValue(y) {
y = 10;
}

changeValue(x);
console.log(x); // 输出:5

在上面的例子中,尽管我们尝试在 changeValue 函数中改变 y 的值,但这并不会影响到原始的 x 变量。这是因为我们实际上传递的是 x 的值,而不是 x 的地址。

然而,JavaScript 中的对象(例如数组或对象字面量)是按引用传递的。这意味着如果你传递的是一个对象,那么函数内部对对象的修改会影响到原始对象。

例如:

let obj = { value: 5 };

function changeObject(o) {
o.value = 10;
}

changeObject(obj);
console.log(obj.value); // 输出:10

在这个例子中,尽管我们传递的是 obj 的一个副本,但由于对象是按引用传递的,所以函数内部对 o 的修改会影响到原始的 obj 对象。

你可能感兴趣的:(javascript)