1.引用类型有哪些?非引用类型有哪些
javascript的数据类型分为基本数据类型和引用类型,基本数据类型包括数值number、字符串string 、布尔型boolean、以及undefined、null两个特殊类型,引用类型包括狭义的对象Object、数组Array、函数Function、正则等。
基本类型的数据是存放在栈内存中的,开辟一个固定大小的空间进行固定位置的保存,并且数据的访问形式是后进先出,而引用类型的数据是存放在堆内存中的,在内存的堆空间开辟一个动态的空间保存来保存数据的值(因为数据的大小不固定),当我们访问这个变量的时候其实是根据储存在栈空间的指针寻址来查找到相应的堆内存空间,因此给基本类型进行重复赋值的时候,基本数据的值不会改变,而引用类型会一起连带改变,因为我们的改变不再是单独去创建一个副本,而是查找了同一个指针引用并改变了其堆内存中的值 。
2.如下代码输出什么?为什么
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);//false,对象是引用类型,obj1和obj2保存的是储存了相同值的对象的地址,并不相同。
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,基本数据类型,值传递,aa和a都有一块自己的栈空间,虽然后面a又重新赋值但只是相当于拷贝了一个值的副本并重新创建了一个栈内存空间在原来的a之上(或后)
console.log(bb) //输出2,原因同上
console.log(cc)//输出{ name: 'hello', age: 2 },引用类型,存储的是地址,cc和c都有同样的一个对象指针或地址,
console.log(dd)//输出 [11,22,{name:'hello',age:3}],通过数组索引改变了原对象c中的age属性,dd和d引用的同一位置的值
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,调用f1(a)的时候有一个赋值动作var n = a;然后再++n,a依旧保持原始值不变
console.log(c)//{ name: 'jirengu', age: 3 },调用f2(c)执行var obj = c;指向同一块堆内存,然后执行++obj.age对象c的age属性加1,c = {name:'jirengu',age:3},再执行f1(c.age),c.age为3,var n=3
5.过滤如下数组,只保留正数,直接在原数组上操作
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
for(var n=0;n<arr.length;n++) {
if (arr[n]<=0) {
arr.splice(n,1);
filter(arr)
}
}
}
filter(arr)
console.log(arr) // [3,1,2]
6.过滤如下数组,只保留正数,原数组不变,生成新数组
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
var newArr=[];
var i=0;
for(var n=0;n<arr.length;n++) {
if (arr[n]>0) {
newArr[i]=arr[n];
i++;
}
}
return newArr;
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr) // [3,1,0,-1,-2,2,-5]
7.写一个深拷贝函数,用两种方式实现
方法一
var obj={
age:100,
friend: {
name:'zn',
sex:'female'
}
}
function copy(obj) {
var newObj = {};
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
if (typeof obj[key] === 'number' || typeof obj[key] === 'string' || obj[key] === undefined || obj[key] === null || typeof obj[key] === 'boolean') {
newObj[key] = obj[key]
}else {
newObj[key] = copy(obj[key]);
}
}
}
return newObj;
}
var obj2= copy(obj)
console.log(obj2)
方法二
var obj={
age:100,
friend: {
name:'zn',
sex:'female'
}
}
function copy(obj){
var newObj=JSON.parse(JSON.stringify(obj));
return newObj;
}
var obj1=copy(obj);
console.log(obj1);