1.引用類型有哪些溯泣?非引用類型有哪些
- 基本類型值(數(shù)值虐秋、布爾值、字符串垃沦、null和undefined):指的是保存在棧內(nèi)存中的簡(jiǎn)單數(shù)據(jù)段客给;
- 引用類型值(對(duì)象、數(shù)組肢簿、函數(shù)靶剑、正則):指的是那些保存在堆內(nèi)存中的對(duì)象,變量中保存的實(shí)際上只是一個(gè)指針池充,這個(gè)指針執(zhí)行內(nèi)存中的另一個(gè)位置桩引,由該位置保存對(duì)象
2.如下代碼輸出什么?為什么
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2); //false 因?yàn)閛bj是引用類型纵菌,obj1保存的變量指針和obj2保存的變量指針并不相同
console.log(obj1 = obj2); //{a: 1, b: 2} 將obj2的地址賦給了obj1阐污,賦值語(yǔ)句最終返回了obj2地址對(duì)應(yīng)存儲(chǔ)的數(shù)據(jù)
console.log(obj1 == obj2); //true 因?yàn)樯弦粋€(gè)語(yǔ)句將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 因?yàn)閍a=a將a的值1賦給了aa
console.log(bb) // 2 因?yàn)閎b=b將b的值2賦給了bb
console.log(cc) // {name: "hello", age: 3} 引用類型指針相等,c.name
console.log(dd)
/*
dd=d={1,2,指向{ name: '饑人谷', age: 2 }} 基本類型賦值之后d里面沒有變量a序苏,b了只有值1,2
a = 11
b = 22 a=11手幢,b=22 與d無(wú)關(guān)
c.name = 'hello' dd.name=c.name="hello" 引用類型指針相等
d[2]['age'] = 3 dd.age=c.age=3 引用類型指針相等
輸出: {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) // c.age=3忱详,3作為參數(shù)傳入c.age不會(huì)變
console.log(a) // 1 n與a沒有關(guān)系
console.log(c) // {name: "jirengu", age: 3} 引用類型指針相等
5.過濾如下數(shù)組围来,只保留正數(shù),直接在原數(shù)組上操作
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.過濾如下數(shù)組匈睁,只保留正數(shù)监透,原數(shù)組不變,生成新數(shù)組
var arr = [3,1,0,-1,-3,2,-5]
function filter(arr){
var newArr = [];
for(var i = 0;i<arr.length;i++) {
if(arr[i] > 0) {
newArr.push(arr[i]);
}
}
return newArr
}
var arr2 = filter(arr)
console.log(arr2) // [3,1,2]
console.log(arr) // [3,1,0,-1,-3,2,-5]
7.寫一個(gè)深拷貝函數(shù)航唆,用兩種方式實(shí)現(xiàn)
function isBasicType(value) {
return !!(typeof value == "number" | typeof value == "string" | typeof value == null | typeof value == undefined | typeof value == "boolean");
}
function deepCopyRecursion(obj) {
var newObj = {};
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
if (isBasicType(obj[key])) {
newObj[key] = obj[key];
} else {
newObj[key] = deepCopy(obj[key]);
}
}
}
return newObj;
}
function deepCopyJson(obj) {
return JSON.parse(JSON.stringify(obj));
}