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

引用类型对象拷贝

作者: saintkl | 来源:发表于2017-07-10 13:56 被阅读0次

    1.引用类型有哪些?非引用类型有哪些

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

    2.如下代码输出什么?为什么

    var obj1 = {a:1, b:2};
    var obj2 = {a:1, b:2};
    console.log(obj1 == obj2);输出//false;因为是两个不同的指针,分别指向不同的堆内的对象
    console.log(obj1 = obj2);//输出Object {a: 1, b: 2};将obj2赋值给obj1;
    console.log(obj1 == obj2);//输出true;引用类型的赋值是对象引用,指向同一个地址

    3.如下代码输出什么? 为什么

    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;
    原因:基本类型的复制,会在变量对象上创建一个新值,然后把该值复制到为新值配置的位置上,该值只是一个副本,可以参与任何操作不受影响。
    console.log(bb) //2 ;
    原因同上
    console.log(cc) // { name: 'hello', age: 3 } ;
    原因:引用类型的复制,同样会在栈中开辟新的空间,是一个副本,但是这个副本是一个指针,这个指针指向同一个对象。因此改变任何一个变量就会影响另个一个变量。操作c.name='hello'改变了对象c的 name为hello;变量d中d[2]的指针指向对象c,操作d[2]['age'],改变了对象c的age为3
    console.log(dd) //[1,2,{ name: 'hello', age: 3 }]
    原因:d 中保存的是基本类型a =1,基本类型b=2,
    引用类型c ,根据之前描述的基本类型赋值,引用类型赋值的特点,a ,b不变,操作c.name = 'hello'
    d[2]['age'] = 3,均影像了对象c;

    4.如下代码输出什么? 为什么

    var a = 1
    var c = { name: 'jirengu', age: 2 }

    function f1(n){
    ++n
    }
    function f2(obj){
    ++obj.age
    }

    f1(a); //没有返回值,同时全局变量a 没赋值
    f2(c); // 没有返回值,但是改变了引用类型c的age为3
    f1(c.age) //没有返回值,同时全局变量a 没赋值
    console.log(a) //1;由于每次操作没给a 赋值,所以a不变。
    console.log(c) // { name: 'jirengu', age: 3 } //操作f2(c)改变了age为3;

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

    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)
              i--;
          } 
        }
    }
    

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

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

    var arr = [3,1,0,-1,-3,2,-5]
    方法一;

    function filter(arr){
    
        var arr2 =  arr.filter(function(item,index,array){//ie8以上
            return (item > 0)
      })
        return arr2;
    }
    

    方法二;

    function filter(arr){
    
        var arr2=[];
        for(var i=0;i<arr.length;i++){
            if(arr[i]>0){    
               arr2.push(arr[i])
          }
        }
        return arr2
    }
    

    var arr2 = filter(arr)
    console.log(arr2) // [3,1,2]
    console.log(arr) // [3,1,0,-1,-2,2,-5]

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

    深拷贝理解:深复制不是简单的复制引用,而是在堆中重新分配内存,并且把源对象实例的所有属性都进行新建复制,复制后的对象与原来的对象是完全隔离的。
    参考网址http://www.cnblogs.com/tracylin/p/5346314.html
    方法一

     var array = {
    
        age:25,
        friends:{
            name:"andy",
            age:16
            }
        }
    function deepCopy(oldObj){
      var newObj = {};
      for(key in oldObj){
        if(typeof oldObj[key]==="object" && oldObj[key]!= null){
            newObj[key]=deepCopy(oldObj[key])
        }else{
            newObj[key]=oldObj[key]
        }
    }
       return newObj;
    }
    var obj2 = deepCopy(array);
    

    方法二

    var source = {
    
              name:"source",
              child:{
              name:"child"
              }
         }
    var target = JSON.parse(JSON.stringify(source));

    相关文章

      网友评论

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

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