美文网首页
引用类型-对象拷贝

引用类型-对象拷贝

作者: osborne | 来源:发表于2017-02-11 18:10 被阅读7次

    一:引用类型有哪些?非引用类型有哪些

    • 引用类型值(对象、数组、函数、正则):指的是那些保存在堆内存中的对象,变量中保存的实际上只是一个指针,这个指针执行内存中的另一个位置,由该位置保存对象。
    • 基本类型值(数值、布尔值、字符串、null和undefined):指的是保存在栈内存中的简单数据段。

    二:如下代码输出什么?为什么

    var obj1 = {a:1, b:2};
    var obj2 = {a:1, b:2};
    console.log(obj1 == obj2); //输出:false , obj1与0bj2指向不同的地址
    console.log(obj1 = obj2); //输出:object {a:1, b:2} , obj2赋值给obj1
    console.log(obj1 == obj2); //输出:ture , obj1与obj2地址相同
    

    三:如下代码输出什么? why

    var a = 1
    var b = 2
    var c = { name: '饥人谷', age: 2 }
    var d = [a, b, c]
    
    var aa = a
    var bb = b
    var cc = c
    var dd = d
    
    a = 11
    b = 22
    c.name = 'hello'
    d[2]['age'] = 3
    
    console.log(aa)  //输出:1 , 基本类型 把a赋值给aa
    console.log(bb)  //输出:2 , 同上
    console.log(cc)  //输出:object {name: "hello", age: 3} , 引用类型 地址相同 d[2]['age'] = 3 改变'age'值 
    console.log(dd)  //输出:[1,2,{name: "hello", age: 3}] , 引用类型 地址相同
    

    四:如下代码输出什么? 为什么

    var a = 1
    var c = { name: 'jirengu', age: 2 }
    function f1(n){
      ++n
    }
    function f2(obj){
      ++obj.age
    }
    f1(a) 
    f2(c) 
    f1(c.age) 
    console.log(a) //输出:1 , 基本类型 a的值赋给了n,++n变化n的值,a不会发生变化
    console.log(c) //输出:object {name: 'jirengu', age: 3} , 引用类型 c指向的地址赋值给了obj
    

    五:过滤如下数组,只保留正数,直接在原数组上操作

    var arr = [3,1,0,-1,-3,2,-5]
    function filter(arr){
    }
    filter(arr)
    console.log(arr) // [3, 1, 0, -1, -3, 2, -5] ,过滤正数后:[3,1,2]
    

    结果:

    var arr = [3,1,0,-1,-3,2,-5]
    function filter(arr){
      for (var i = 0; i < arr.length; i++){
        if (arr[i] <= 0){
          arr.splice(i, 1);
          filter(arr);
        }
      }
    }
    filter(arr)
    console.log(arr) // [3,1,2]
    

    六:过滤如下数组,只保留正数,原数组不变,生成新数组

    var arr = [3,1,0,-1,-3,2,-5]
    function filter(arr){
    }
    var arr2 = filter(arr)
    console.log(arr2) // undefined,生成新数组:[3,1,2]
    console.log(arr)  // [3,1,0,-1,-3,2,-5],生成新数组:[3,1,0,-1,-2,2,-5]
    

    结果:

    var arr = [3,1,0,-1,-3,2,-5]
    function filter(arr){
      var newArr = []; 
      var j = 0;
        for (var i = 0; i < arr.length; i++) {
          if (arr[i] > 0 ) {
            newArr[j] = arr[i];
              j++;
        }
        }
        return newArr;
    }
    var arr2 = filter(arr)
    console.log(arr2) // [3,1,2]
    console.log(arr)  // [3,1,0,-1,-2,2,-5]
    

    七:写一个深拷贝函数,用两种方式实现

    第一种

    function deepCopy(oldObj){
      var newObj = {};
      for(var key in oldObj){
        if(typeof oldObj[key] === 'number' || typeof oldObj[key] === 'string' || typeof oldObj[key] === 'boolen' || oldObj[key] === null || oldObj[key] === undefined){ 
          newObj[key] = oldObj[key];
          }
        else{
          newObj[key] = deepCopy(oldObj[key]);
          }
      }
      return newObj;
    }
    

    第二种

     function deepCopy(oldObj){
            var newObj = JSON.parse(JSON.stringify(oldObj));
            return newObj;
     }
    
    • 第一种深拷贝是直接用json的方法转两次,然后直接生成一个新对象的。第二种方法是深层次的遍历赋值

    相关文章

      网友评论

          本文标题:引用类型-对象拷贝

          本文链接:https://www.haomeiwen.com/subject/oxcoittx.html