C 拷貝建構函式

2021-07-22 19:38:52 字數 1576 閱讀 8270

1.**格式牢記。類名(const 類名 &x)

2.該函式的三種呼叫時機。

3.淺拷貝與深拷貝(是否有動態成員變數)。

例1:

#include using namespace std;  

class cexample

//拷貝建構函式

cexample(const cexample& c)

//一般函式

void show ()

//拷貝構造

cexample(const cexample& c)

this->a = rhs.a;

return *this;

}

系統自帶預設的拷貝建構函式。

只對物件中的資料成員進行簡單的賦值。大多數情況下「淺拷貝」已經能很好地工作了,但是一旦物件存在了動態成員,那麼拷貝就會出問題了。如下**:

class rect  

~rect() // 析構函式,釋放動態分配的空間

} private:

int width;

int height;

int *p; // 一指標成員

};

int main()

error:進行物件複製時,對於動態分配的內容沒有進行正確的操作。

在執行定義rect1物件後,由於在建構函式中有乙個動態分配的語句,因此執行後的記憶體情況大致如下:

在使用rect1複製rect2時,由於執行的是拷貝,只是將成員的值進行賦值,這時rect1.p=rect2.p,也即這兩個指標指向了堆裡的同乙個空間,如下如所示:

當然,這不是我們所期望的結果,在銷毀物件時,兩個物件的析構函式將對同乙個記憶體空間釋放兩次,這就是錯誤出現的原因。我們需要的不是兩個p有相同的值,而是兩個p指向的空間有相同的值。解決辦法就是使用「深拷貝」。

在「深拷貝」的情況下,對於物件中動態成員,應該重新動態分配空間,如下所示。

class rect  

rect(const rect& r)

~rect() // 析構函式,釋放動態分配的空間

} private:

int width;

int height;

int *p; // 一指標成員

};

完成物件複製後,記憶體情況如下所示:

此時rect1的p和rect2的p各自指向一段記憶體空間,但它們指向的空間具有相同的內容,這就是所謂的「深拷貝」。

參考:

C 建構函式 拷貝建構函式

建構函式 class base private int m var 建構函式無返回值型別,函式名和型別相同。拷貝建構函式傳遞引數為引用。1 class base2 7 拷貝建構函式 8 base base ref m var ref m var 9 11 private 12 intm var 13...

C 拷貝建構函式

1 什麼時候會用到拷貝建構函式?當任何你想影印東西的時候,而不管東西被影印成什麼樣子。即任何你想利用乙個已有的類例項給另乙個類例項賦值時,這種賦值可能是顯式的,也可能是隱式的 顯式 classa 1 class 2 隱式 函式的形參有用到類物件卻沒有用引用或傳址技術時 函式的返回值是乙個物件也沒有應...

C 拷貝建構函式

1 拷貝構造 copy建構函式用於將乙個物件拷貝到新建立的物件中。也就是說它用於初始化過程中,而不是常規的賦值過程中。一般的copy建構函式原型通常如下 class name const class name rhs 它接受乙個指向類物件的常量引用作為引數。例如,cstring類的拷貝建構函式的原型...