引用类型与对象拷贝
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;
}