記錄一次JS 的淺拷貝和深拷貝

簡(jiǎn)單理解淺拷貝和深拷貝

博客地址:https://www.zhouhaipeng.com/
github https://github.com/Roc-zhou

什么是淺拷貝椅挣?

簡(jiǎn)單來(lái)說(shuō) 有個(gè) A 和 B,我們把A 復(fù)制給了B秩伞,當(dāng)我們修改B 的時(shí)候 發(fā)現(xiàn) A 的值也會(huì)發(fā)生改變吁伺,這就是淺拷貝

  • 舉個(gè)例子
let a = [{ name: '張三' }],
b = a

b[0].name = '李四'
console.log(a);  // [{ name: '李四' }]
console.log(a); //  [{ name: '李四' }]
  • 使用圖解釋一下


    9419407-1d09c5b4a0a06252.png

    9419407-ff2d0c88f14929a3.png

從圖中我們可以看到 a和b 全部 都指向了 同一個(gè) 堆內(nèi)存的值 饮睬,所以我們改變 b 的數(shù)據(jù) a也會(huì) 改變 。

那什么是深拷貝呢篮奄?

理解了淺拷貝捆愁,我猜 深拷貝就是修改 b 的值 a 還是原來(lái)的值。

  • 還是舉個(gè)例子先
// 深拷貝的方法有幾種 這里只寫(xiě)一種 (JSON.stringify窟却、jquery等)
function clone(obj) {
  let result = obj.constructor === Array ? [] : {};
  if (typeof obj !== 'object') {
    return obj;
  }
  for (const x in obj) {
    if (obj.hasOwnProperty(x)) {
      if (typeof obj[x] === 'object' && obj[x] !== null) {
        result[x] = clone(obj[x]);   //遞歸復(fù)制
      } else {
        result[x] = obj[x];
      }
    }
  }
  return result
}

let a = [{ name: '張三' }],
  b = clone(a)

console.log(a); // [ { name: '張三' } ]
console.log(b); // [ { name: '張三' } ]
// 成功復(fù)制
// 修改b的值
b[0].name = '李四'
console.log(a); // [ { name: '張三' } ]
console.log(b); // [ { name: '李四' } ]
  • 還是上個(gè)圖


    9419407-efe13a61709541e3.png

    9419407-47e577f9b52cb1c7.png

從圖上我們可以看到 b 復(fù)制 a 是在 堆內(nèi)存中復(fù)制了一個(gè)生成了一個(gè)新的昼丑,所以我們修改b 的值的時(shí)候 a 不會(huì)受影響,這樣我們就得到了一個(gè)新的b 達(dá)到了深拷貝的效果夸赫!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末菩帝,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子茬腿,更是在濱河造成了極大的恐慌呼奢,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,997評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件切平,死亡現(xiàn)場(chǎng)離奇詭異握础,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)悴品,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,603評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)禀综,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人他匪,你說(shuō)我怎么就攤上這事菇存。” “怎么了邦蜜?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,359評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)亥至。 經(jīng)常有香客問(wèn)我悼沈,道長(zhǎng),這世上最難降的妖魔是什么姐扮? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,309評(píng)論 1 292
  • 正文 為了忘掉前任絮供,我火速辦了婚禮,結(jié)果婚禮上茶敏,老公的妹妹穿的比我還像新娘壤靶。我一直安慰自己,他們只是感情好惊搏,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,346評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布贮乳。 她就那樣靜靜地躺著忧换,像睡著了一般。 火紅的嫁衣襯著肌膚如雪向拆。 梳的紋絲不亂的頭發(fā)上亚茬,一...
    開(kāi)封第一講書(shū)人閱讀 51,258評(píng)論 1 300
  • 那天,我揣著相機(jī)與錄音浓恳,去河邊找鬼刹缝。 笑死,一個(gè)胖子當(dāng)著我的面吹牛颈将,可吹牛的內(nèi)容都是我干的梢夯。 我是一名探鬼主播,決...
    沈念sama閱讀 40,122評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼晴圾,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼厨疙!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起疑务,我...
    開(kāi)封第一講書(shū)人閱讀 38,970評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤沾凄,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后知允,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體撒蟀,經(jīng)...
    沈念sama閱讀 45,403評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,596評(píng)論 3 334
  • 正文 我和宋清朗相戀三年温鸽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了保屯。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,769評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡涤垫,死狀恐怖姑尺,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蝠猬,我是刑警寧澤切蟋,帶...
    沈念sama閱讀 35,464評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站榆芦,受9級(jí)特大地震影響柄粹,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜匆绣,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,075評(píng)論 3 327
  • 文/蒙蒙 一驻右、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧崎淳,春花似錦堪夭、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,705評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)恨豁。三九已至,卻和暖如春拗秘,著一層夾襖步出監(jiān)牢的瞬間圣絮,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,848評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工雕旨, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留扮匠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,831評(píng)論 2 370
  • 正文 我出身青樓凡涩,卻偏偏與公主長(zhǎng)得像棒搜,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子活箕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,678評(píng)論 2 354