为了脱发
2021-02-22 18:45
采纳率: 100%
浏览 286

js 函数里面对数组进行赋值,不会改变原数组?

输出还是 [1,2,3] 是怎么回事

        let arr = [1,2,3];

        change(arr);

        console.log(arr); //  [1,2,3]

        function change (arr){
            arr = [];
        }
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • 天际的海浪 2021-02-22 22:18
    已采纳

    举例说明吧

    var a = [1,2,3]; //a中存储的是数组的引用地址,这个数组我起名叫“数组1”
    var b = a; // a赋值给b,b中也存储了“数组1”的引用地址

    b[1] = 4; // 对 b[1] 赋值并不是直接改变b中存储的内容,而是读取b中存储的引用地址,通过这个引用地址找到“数组1”,再对“数组1”的[1]属性进行赋值。
    //这样对b本身而言只是读取操作,b中存储的内容没有改变,依然与a中存储的引用地址一样。

    //同样的
    b.push(5); // 也是先读取b中存储的引用地址,通过这个引用地址找到“数组1”,再调用“数组1”的push方法对“数组1”中的属性添加。
    //这样对b本身而言也只是读取操作,b中存储的内容没有改变,依然与a中存储的引用地址一样。


    //但下面就不同了
    b = [7,8,9]; //将一个新的数组赋值给b,这个新的数组我起名叫“数组2”
    // 这回对b本身而言就是写入操作了,b中存储的内容变成“数组2”的引用地址。
    // 但是a中存储的引用地址没有变,还是原来存储的“数组1”的引用地址。
    // 这样a和b的关联就断开了。
     

    已采纳该答案
    1 打赏 评论
  • 天际的海浪 2021-02-22 18:54

    js中对象和数组都是一律传引用的。
    引用不同于C语言中的指针。引用只在读取数据时有效,当对变量写入数据时,原有的引用就会断开。
     

    1 打赏 评论
  • LILEILEILOVE 2021-02-23 00:33
      let arr = [1, 2, 3];
    
            change(arr);
    
            console.log(arr); //  [1,2,3]
    
            function change(arr) {
                arr = [];
                console.log(arr) //  []   此处打印为空数组
            }
    
            console.log(arr) //  [1,2,3]
    打赏 评论

相关推荐 更多相似问题