Javascript 對象複製(深淺拷貝)

來源:互聯網
上載者:User

標籤:基礎類型   另一個   複製   clone   大致   淺複製   alt   兩種   htm   

要弄懂這些概念,著實不易,尤其是深淺拷貝。這裡舉個不恰當例子便於理解,淺拷貝是雙胞胎,深拷貝是單獨複製自己。

一、資料類型分類:

二、什麼叫做指標指向

棧記憶體、堆記憶體、指標指向(如下紅圈圈的斜線)。

三、賦值、拷貝、引用區別?
  1. 賦值一個變數賦予某個值,包含兩種方式,一種是直接量,另一種,是將另一個變數的值傳遞給這個變數。拷貝和引用都屬於後者
  2. 引用的目的將指標指向相同堆記憶體中的某一位置
  3. 拷貝的目的改變指標的指向,並且內部屬性或者元素的值相等。基礎資料類型在賦值過程就改變了指標指向,所以通常說,基礎類型的引用只存在唯讀狀態。複雜資料類型的指標指向包含兩種一種是指標指向棧記憶體,另一種是指標指向堆記憶體,前者只需賦值即可,可後者沒那麼容易。
var person =  {  name: ‘lc‘,  friends: [‘xm‘,‘xm‘,‘xl‘]}

從這段代碼,我們很清楚知道person.nameperson.friends中的每個元素的指標指向棧記憶體,personperson.friends的指標指向堆記憶體,由此我們可以得出兩點:

  1. 拷貝改變複雜資料類型的指標指向,必須是先改變指向堆記憶體的指標指向,如person的指標指向。
  2. 拷貝改變指標指向,可以只改person的指標向,這類叫做淺拷貝(淺複製);也可以改變personperson.friends等全部指標指向,這類通常叫做深拷貝(深複製)。
四、淺拷貝和深拷貝

在上面,我已描敘了淺拷貝和深拷貝,在這裡再嚴謹的總結一下:淺拷貝只改變複雜資料類型內部分的指標指向,也就是不完全改變;深拷貝徹頭徹底地改變所有指標指向,也就是完全改變

淺拷貝

以上例代碼為例:

var shallow_copy={};for(var i in person) {  shollow_copy[i] = person[i];}

或者 es6 的 Object.assign()

深拷貝

實現的方法也是多種,大致上可以分為兩類: 一類是json,另一類是遞迴迴圈遍曆賦值。

其中最常見的是JQuery中$.extend()

其他

理解這些,像es6文法中const,es6模組和commonJS模組的區別等問題就變得非常好理解。

本文是參考眾多文章,並自己總結得出的,若有什麼不對,請見諒和指出。

像如何驗證淺拷貝至改變部分指標指向、深拷貝具體實現方法有哪些等問題,也可以參考下面文檔:

文檔1
文檔2
文檔3

[源碼示範,待續。。。]

Javascript 對象複製(深淺拷貝)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.