引用类型对象拷贝

96
Wensx
2017.08.02 08:59* 字数 238

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); //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 } var cc = c 是将c的对象地址赋给cc,var d = [a, b, c]也是将c对象的地址赋值给d数组中的c变量,var dd = d是将d的数组地址复制给dd;所以任意对c的改变都会反应到有c的地址的对象中。
console.log(dd)//[1, 2, { name: 'hello', age: 3 }]// 基本类型直接赋值,dd中的a b为初始a b的值

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

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进行增减,f1只是读取a的值,复制给了n,n!=a
console.log(c); // Object {name: "jirengu", age: 3} f2函数读取了c对象的地址,并且将对应地址的age的值+1; f1函数只是读取了c对象age的值,复制给了n.

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--;
     }    
  }
  return arr;
}
filter(arr);
console.log(arr); // [3,1,2]

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

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

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

方法1:
var arr = [3,1,0,-1,-3,2,-5,[1,2]];
function deepCopy(obj) {
    var b = [];
    for (key in obj) {
        if (typeof obj[key] === 'object'){
            b[key]=deepCopy(obj[key]);
        }else if(typeof obj[key] === 'number'||typeof obj[key] === 'string'||typeof obj[key] === 'boolean'||obj[key] === undefined || obj[key] === null){
            b[key]=obj[key];
        }
    }
    return b;
}
var arr2 = deepCopy(arr);
arr[7][1]=6;
console.log(arr2) ;// [ 3, 1, 0, -1, -3, 2, -5, [ 1, 2 ] ]
console.log(arr) ; //[ 3, 1, 0, -1, -3, 2, -5, [ 1, 6 ] ]
方法2:
var arr = [3,1,0,-1,-3,2,-5,[1,2]];
var b = JSON.parse( JSON.stringify(arr) );
arr[7][1]=6;
console.log(b) ;// [ 3, 1, 0, -1, -3, 2, -5, [ 1, 2 ] ]
console.log(arr) ; // [ 3, 1, 0, -1, -3, 2, -5, [ 1, 6 ] ]
Javascript
Web note ad 1