《论JS函数传参时: 值传递与引用传递的区别》

1. 值传递(简单类型): -- -- --number、 string、 boolean
**在值传递的过程中, 值是在栈中存储的**
eg:
    var num = 10;
    var num2 = num; //传递的是值
    console.log(num2); //结果为10

解析:num将自身的值传递给num2,相当于num2=num=10.

2. 引用传递(复杂类型): -- -- --object/function
**对象在堆中存储, 地址在栈中存储**
eg:
 function fn(x) {
        x = 100;
    }
    var num = 10;
    fn(num); //传递的是地址
    console.log(num); //结果为10
eg2:
    var obj = {
            name: "tom"
    }; //存储在堆中

    function fn(obj2) {
        obj2.name = "annly"
    }
    console.log(obj.name); //结果为tom
    fn(obj);
    console.log(obj.name); //结果为annly
解释:
1. 首先obj在栈中开辟了一个空间, 名字叫obj
2. 其次obj中的name: "tom", 存储在堆中, 这个堆的名字为0x120
3. 然后将这个地址名存储在obj在栈中开辟的空间中, obj指向堆中的name: "tom"
4. obj2也在栈中开辟了一个空间, 然后fn(obj);这个语句是将obj传给obj2, 此时obj中存储的是0x120这个地址, 所以obj将地址传给了obj2, 即obj2具有与obj相同的地址
5.  obj2中具有obj2.name = "annly", 所以将name: "tom", 替换成obj2.name = "annly"


**总结: 值类型之间传递的是值
引用类型之间传递的是地址
值类型作为函数的参数, 传递的是值
引用类型作为函数的参数, 传递的是地址,而不是引用类型本身**

你可能感兴趣的:(《论JS函数传参时: 值传递与引用传递的区别》)