引用類型與對象拷貝

  1. 引用類型有哪些希柿?非引用類型有哪些
  • 基本類型诊沪,數(shù)值、布爾值曾撤、字符串端姚、null和undefined:指的是保存在棧內(nèi)存中的簡單數(shù)據(jù)段;
  • 引用類型挤悉,對象渐裸、數(shù)組、函數(shù)装悲、正則:指的是那些保存在堆內(nèi)存中的對象,變量中保存的實際上只是一個指針载迄,這個指針執(zhí)行內(nèi)存中的另一個位置,由該位置保存對象
  1. 如下代碼輸出什么极祸?為什么
var obj1 = {a:1, b:2};
var obj2 = {a:1, b:2};
console.log(obj1 == obj2);  //false蒜田,引用類型在內(nèi)存棧中保存的只是一個函數(shù)指針美莫,兩者占據(jù)不同的地址
console.log(obj1 = obj2);  //object{a: 1, b: 2}傀顾,將 obj2 的指針復(fù)制給 obj1,輸出對象 obj1
console.log(obj1 == obj2);  //true哩都,復(fù)制后指針相同
  1. 如下代碼輸出什么儒鹿?為什么
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锌仅,基本類型贱傀,直接復(fù)制值
console.log(bb)  //2报腔,同上
console.log(cc) 
 //{name: "hello", age: 3},引用類型炮姨,將 c 的指針復(fù)制給 cc,c.name = 'hello'、d[2]['age'] = 3 改變了指針指向?qū)ο蟮膬?nèi)容,
console.log(dd)  //[1, 2, {name: "hello", age: 3}],引用類型,淺拷貝褥紫,將 d 的指針復(fù)制給 dd
  1. 如下代碼輸出什么氨菇?為什么
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豌研,相當(dāng)于基本類型,復(fù)制變量值,n = a; ++n,而 a 的值仍為 1
console.log(c)  //{name: "jirengu", age: 3},相當(dāng)于引用類型凌蔬,復(fù)制指針,改變了指針指向?qū)ο蟮闹?
  1. 過濾如下數(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)
    }
  }
}
filter(arr)
console.log(arr) // [3,1,2]
  1. 過濾如下數(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,-2,2,-5]
  1. 寫一個深拷貝函數(shù),用兩種方式實現(xiàn)
  • 方法一:遞歸
var obj = {
  name: 'Mark',
  age: '25',
  hobby: ['reading', 'workout', 'sci-fi']
}
function deepCopy(obj){
  var newObj = {}
  for(var key in obj) {
    if(obj.hasOwnProperty(key)) {
      if(typeof obj[key]==='number'||typeof obj[key]==='boolean'||typeof obj[key]==='string'||obj[key]===undefined||obj[key]===null)
      {
      newObj[key] = obj[key]
    } else {
      newObj[key] = deepCopy(obj[key])
    }
  }
  }
  return newObj
}
var obj1 = deepCopy(obj)
console.log(obj1)
  • 方法二:json解析
//JSON.parse() 方法將一個 json 字符串轉(zhuǎn)換為對象
//JSON.stringify() 方法將 js 對象轉(zhuǎn)換為字符串
var obj1 = JSON.parse(JSON.stringify(obj));
console.log(obj1)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末殖妇,一起剝皮案震驚了整個濱河市座每,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌秦陋,老刑警劉巖大磺,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異琉苇,居然都是意外死亡嘲玫,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門并扇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來去团,“玉大人,你說我怎么就攤上這事穷蛹⊥僚悖” “怎么了?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵肴熏,是天一觀的道長旺坠。 經(jīng)常有香客問我,道長扮超,這世上最難降的妖魔是什么取刃? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮出刷,結(jié)果婚禮上璧疗,老公的妹妹穿的比我還像新娘。我一直安慰自己馁龟,他們只是感情好崩侠,可當(dāng)我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著坷檩,像睡著了一般却音。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上矢炼,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天系瓢,我揣著相機與錄音,去河邊找鬼句灌。 笑死夷陋,一個胖子當(dāng)著我的面吹牛欠拾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播骗绕,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼藐窄,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了酬土?” 一聲冷哼從身側(cè)響起荆忍,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎撤缴,沒想到半個月后刹枉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡腹泌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年嘶卧,在試婚紗的時候發(fā)現(xiàn)自己被綠了尔觉。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片凉袱。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖侦铜,靈堂內(nèi)的尸體忽然破棺而出专甩,到底是詐尸還是另有隱情,我是刑警寧澤钉稍,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布涤躲,位于F島的核電站,受9級特大地震影響贡未,放射性物質(zhì)發(fā)生泄漏种樱。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一俊卤、第九天 我趴在偏房一處隱蔽的房頂上張望嫩挤。 院中可真熱鬧,春花似錦消恍、人聲如沸岂昭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽约啊。三九已至,卻和暖如春佣赖,著一層夾襖步出監(jiān)牢的瞬間恰矩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工憎蛤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留枢里,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像栏豺,于是被迫代替她去往敵國和親彬碱。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 基本類型和引用類型# ECMAScript包含兩種不同的數(shù)據(jù)類型:基本類型值和引用類型值; 基本類型值指的是保存在...
    草鞋弟閱讀 497評論 0 0
  • 引用類型有哪些奥洼?非引用類型有哪些 引用類型:Object巷疼、Array、Date灵奖、RegExp嚼沿、Function、M...
    _Dot912閱讀 331評論 0 3
  • 1.引用類型有哪些瓷患?非引用類型有哪些骡尽? 引用類型:對象、數(shù)組擅编、函數(shù)攀细、正則表達式非引用類型:數(shù)值、字符串爱态、布爾值谭贪、n...
    BAWScipes閱讀 175評論 0 0
  • [夏桀]史官嘆紅顏禍水,而不責(zé)君王貪杯锦担。區(qū)區(qū)天下怎及俭识,妺喜半分之美。 [商紂]君怨酒池肉林洞渔,不見東夷平定套媚。妲己本是...
    墨凌云閱讀 275評論 5 5
  • 首先聲明,這個故事的真實性磁椒,大家毋庸置疑堤瘤。寫出來這個事情,只是想記錄下來衷快,自己生活的一段真實經(jīng)歷宙橱,盡管那么不可思議...
    鄭州小強閱讀 1,087評論 2 2