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;
}
只對物件中的資料成員進行簡單的賦值。大多數情況下「淺拷貝」已經能很好地工作了,但是一旦物件存在了動態成員,那麼拷貝就會出問題了。如下**:
error:進行物件複製時,對於動態分配的內容沒有進行正確的操作。class rect
~rect() // 析構函式,釋放動態分配的空間
} private:
int width;
int height;
int *p; // 一指標成員
};
int main()
在執行定義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類的拷貝建構函式的原型...