今天早上讀《effective c++》的第五章條款,想到的深拷貝、淺拷貝,對應值拷貝和位拷貝。
值拷貝和位拷貝的內容如下:
c++中的位拷貝和值拷貝
為了便於說明我們以string類為例:
首先定義string類,而並不實現其成員函式。
class string;
位拷貝拷貝的是位址,而值拷貝則拷貝的是內容。如果定義兩個string物件a和b。a.m_data和b.m_data分別指向一段區域,a.m_data="windows",b.m_data=「linux";
如果未重寫賦值函式,將b賦給a,則編譯器會預設進行位拷貝,a.m_data=b.m_data,此為淺拷貝。
則a.m_data和b.m_data指向同一塊區域,雖然a.m_data指向的內容會改變成"linux",但是這樣容易出現這些問題:
(1):a.m_data原來指向的記憶體區域未釋放,造成記憶體洩露。
(2):a.m_data和b.m_data指向同一塊區域,任何一方改變都會影響另一方
(3):當物件被析構時,b.m_data被釋放兩次。
對於編譯器,如果不主動編寫拷貝函式和賦值函式,它會以「位拷貝」的方式自動生成預設的函式。
如果重寫賦值函式和拷貝建構函式後,
a.m_data=b.m_data,進行的是值拷貝,會將b.m_data的內容賦給a.m_data,a.m_data還是指向原來的記憶體區域,但是其內容改變。
實現深拷貝需要2句話:
m_data = new char(sizeof(b.m_data));
mmcpy(m_data, b.m_data, sizeof (b.m_data));
如果淺拷貝(編譯器預設提供) 就是
m_data = b.m_data
顯然2者有很大的不同,
這就是為什麼當型別為hasptr即型別為帶有指標成員的類的時候,要自己實現複製建構函式的原因
C 中的位拷貝和值拷貝
為了便於說明我們以string類為例 首先定義string類,而並不實現其成員函式。class string 位拷貝拷貝的是位址,而值拷貝則拷貝的是內容。如果定義兩個string物件a和b。a.m data和b.m data分別指向一段區域,a.m data windows b.m data lin...
C 中的位拷貝和值拷貝
原帖 http blog.csdn.net liam1122 archive 2007 12 25 1966617.aspx 為了便於說明我們以string類為例 首先定義string類,而並不實現其成員函式。class string 位拷貝拷貝的是位址,而值拷貝則拷貝的是內容。如果定義兩個stri...
C 中的位拷貝和值拷貝
為了便於說明我們以string類為例 首先定義string類,而並不實現其成員函式。class string 位拷貝拷貝的是位址,而值拷貝則拷貝的是內容。如果定義兩個string物件a和b。a.m data和b.m data分別指向一段區域,a.m data windows b.m data lin...