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

引用类型与对象拷贝

作者: BAWScipes | 来源:发表于2017-09-23 23:52 被阅读0次
    1.引用类型有哪些?非引用类型有哪些?

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

    2.如下代码输出什么?为什么
      var obj1 = {a:1, b:2};
      var obj2 = {a:1, b:2};
      console.log(obj1 == obj2); //false  指向的地址不一样
      console.log(obj1 = obj2);   //{a:1,b:2}  将obj2赋值给obj1,指向了同一个地址
      console.log(obj1 == obj2);  //true   指向的地址是同一个
    

    输出结果:false {a:1,b=2} true

    3.如下代码输出什么?为什么
      var a = 1
      var b = 2
      var c = { name: '饥人谷', age: 2 }  //0xx11
      var d = [a, b, c]  //0xx22
      var aa = a  //1
      var bb = b  //2
      var cc = c  //0xx11
      var dd = d  //0xx22
      a = 11
      b = 22
      c.name = 'hello'
      d[2]['age'] = 3
      console.log(aa)   //1
      //a=1,把a赋值给aa,aa=1
      console.log(bb)    //2
      //b=2,把b赋值给bb,bb=2
      console.log(cc)   // {name:"hello",age: 3}
      //把c的值赋给cc,cc就和c指向同样的地址;c.name='hello',c的name值发生变化,cc的name值也跟着一起变化; d[2]['age'] = 3,改变的是c的age值,cc和c指向同样的地址,所以cc的age值也发生变化
      console.log(dd)   // [1, 2, {name:"hello",age: 3}] 
      //d=[1,2,{ name: '饥人谷', age: 2 }],把d的值赋给dd,dd就和d指向同样的地址;c.name='hello',c的name值发生变化,d和dd中的name也跟着发生变化,然后d[2]['age'] = 3,d和dd中的age也随着变成3
    

    输出结果:1 2 {name:"hello",age: 3} [1, 2, {name:"hello",age: 3}]

    4.如下代码输出什么?为什么
      var a = 1
      var c = { name: 'jirengu', age: 2 }
      function f1(n){  //把a的值复制给n,n=a;  把c.age的值赋给n,n=c.age
        ++n   //2 4
      }
      function f2(obj){  //把c的值赋给obj,obj=c;
        ++obj.age  //{ name: 'jirengu', age: 3 }
      }
      f1(a)   
      f2(c) 
      f1(c.age)  //把c.age的值赋给n,n的值发生了变化,对c.age没有影响
      console.log(a)   //1
      //a的值赋给n,n发生变化,a没有变化,a的值为1
      console.log(c)   //{ name: 'jirengu', age: 3 }
      ////把c的值赋给obj,obj和c指向同样的地址,obj.age发生变化,c.age也跟着变化
    

    输出结果: 1 { name: 'jirengu', 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=[];
         for(var i = 0; i < arr.length; i++){
            arr2[i] = arr[i];
       }
       for(var i = 0; i < arr2.length; i++){
           if(arr2[i] <= 0){
             arr2.splice(i,1);
             i--;
          }    
        }
      return arr2;
      }
      var arr2 = filter(arr)
      console.log(arr2) // [3,1,2]
      console.log(arr)  // [3,1,0,-1,-2,2,-5]
    
    7.写一个深拷贝函数,用两种方式实现
        function deepCopy(){
          var obj2={};
          for(var key in obj){
            if(obj.hasOwnProperty[key]){
               if(typeof obj[key] === "number" || typeof obj[key] === "boolean"
               || typeof obj[key] === "string" || obj[key] === null  || obj[key] === undefined){
                obj2[key] =obj[key];
              }else{
                obj2[key] = deepCopy(obj[key]);
              }
            }
          }
          return obj2;
        }
    
      function deepCopy(obj){
        var obj2={};
        obj2=JSON.parse(JSON.stringify(obj));
        return obj2;
      }
    

    相关文章

      网友评论

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

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