引用类型与对象拷贝

2017-09-23  本文已影响0人  BAWScipes
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;
  }
上一篇下一篇

猜你喜欢

热点阅读