引用类型和对象拷贝

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

引用类型:数组,对象,函数,正则.引用类型是指实质内容保存在堆内存,栈内存只保存保存内容的堆内存的地址的类型.
非引用类型:数值,布尔值,undefined,null和字符串.非引用类型是指保存在栈内存的类型.

2.如下代码输出什么?为什么
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);//false
console.log(obj1 = obj2);
console.log(obj1 == obj2);//true

obj1和obj2都是引用类型,虽然对象内容相同,但是指向地址不同,仅仅是内容相同,所以第一个是false.第二个是赋值,把obj2的地址赋给obj1.第三个因为第二个地址赋值的关系,所以是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}
console.log(dd)//[1,2,{name:'hello',age:3}]

因为a和b是非引用类型,a和b在改变值后没有重新赋值,所以a和b的值没有改变,aa和bb的值也没有改变,aa是1,bb是2.c是对象,是引用类型,c.name='hello',d[2]['age']=3改变了c的堆内存的内容,值也就跟着变了,所以cc是{name:'hello',age:3}.dd是数组,数组内容是a,b,c的内容,所以是[1,2,{name:'hello',age:3}]

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 
console.log(c)//{name:'jirengu',age:3}

执行f1()时a为参数,相当于在在函数内部有var n = a这句话,把a的值赋给n,对a是没有影响的,所以a还是1.最后在调用f1(c.age)的时候其实默认的也是通过给var n 赋值 3,这样即便进行了++n的操作,但也没有改变原始的c.age的值.
执行f2(c)时,因为c时引用类型,相当于把c的地址赋给了obj,所以obj.age+1后,堆内存内的内容也跟着改变了,c也就跟着改变了.

5.过滤如下数组,只保留正数,直接在原数组上操作
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
}
filter(arr)
console.log(arr) // [3,1,2]
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
    for (var i=0;i
6.过滤如下数组,只保留正数,原数组不变,生成新数组
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr)  // [3,1,0,-1,-3,2,-5]
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
    var narr = [];
    for (var i=0;i0){
            narr.push(arr[i]);
        }
    }
    return narr;
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr)  // [3,1,0,-1,-3,2,-5]

7.写一个深拷贝函数,用两种方式实现
function copy(obj) {
    var nobj = {};
    for (var key in obj){
        if (typeof obj[key] === "object"){
            nobj[key] = copy(obj[key]);
        }
        else{
            nobj[key] = obj[key];
        }
    }
    return nobj;
}
function deepCopy(obj) {
    var newObj = JSON.parse(JSON.stringify(obj));
    return newObj;
}

你可能感兴趣的:(引用类型和对象拷贝)