當用乙個已經初始化過了的自定義類型別物件去初始化另乙個新構造的物件的時候,拷貝建構函式就會被自動呼叫,如果你沒有自定義拷貝建構函式的時候系統將會提供給乙個預設的拷貝建構函式來完成這個過程。
簡單來說就是以乙個已存在的物件為模型建立乙個新物件
拷貝建構函式的兩種呼叫形式:(a
)a a;
a a1 = a;//
隱式呼叫拷貝建構函式(b
)a a1;
a a2(a1);//
顯式呼叫拷貝建構函式
預設拷貝建構函式,執行的是簡單的記憶體拷貝
---
淺拷貝(
1)淺拷貝
只拷貝位址,而不是對指標指向空間的拷貝,會造成
2個指標指向同乙個空間(2
)深拷貝
為指標建立新空間,拷貝指標指向空間的內容
,注意關鍵是成員屬性值的拷貝。
宣告形式:
person(const person & p)
拷貝建構函式是一類特殊的建構函式,是在用同一型別的物件初始化乙個新生成的物件時被呼叫的。這樣,如果拷貝建構函式的引數不是引用的話,那引數傳遞是值傳遞的過程,其實就是乙個初始化的過程,而且同型別的物件初始化另一物件,因此這個過程中又要呼叫拷貝建構函式
……這是乙個無限迴圈的過程。為了避免這個問題,拷貝建構函式的引數必須是引用。
情況1:呼叫預設拷貝函式
class person
};void fn( person p )
int main()
結果是: person()
hello5
hello5
~person()
~person()
注意:呼叫了兩次析構,只建立了乙個物件
情況2:自己寫乙個拷貝建構函式
person(const person &p)
拷貝建構函式,預設拷貝建構函式
拷貝建構函式,預設拷貝建構函式 1.c 的預設拷貝建構函式,從深度拷貝和淺拷貝說起 c 類的預設拷貝建構函式的弊端 c 類的中有兩個特殊的建構函式,1 無參建構函式,2 拷貝建構函式。它們的特殊之處在於 1 當類中沒有定義任何建構函式時,編譯器會預設提供乙個無參建構函式且其函式體為空 2 當類中沒有...
建構函式 拷貝建構函式
建構函式可以分為三類 1 不帶引數的建構函式 在函式體中對資料成員賦初值,這種方式使該類的每乙個物件都得到同一組初值 2 帶引數的建構函式 如果使用者希望對不同的物件賦不同的初值,可以採用帶引數的建構函式。在呼叫不同物件的建構函式時從外面將不同的資料傳遞給建構函式,以實現初始化 3 複製建構函式 建...
建構函式 拷貝建構函式
person person 引用就是指標常量 所以person p person const p,引用所以一旦初始化指向某個位址,就不能在改變了。為什麼前面還要加const,因為拷貝建構函式的目的就是將乙個物件的所有屬性拷貝到另外乙個物件,這個物件的屬性不變,加上const 相當於 const pe...