類的拷貝建構函式
class cexample
cexample(const cexample & c)
1.它是乙個 建構函式!
2.第乙個預設的引數必須是 cexample & 形式的;
3.如果乙個類中沒有定義拷貝建構函式,那麼編譯器會自動產生乙個預設的拷貝建構函式。
這個預設的引數可能為
x::x(const x&)
或 x::x(x&)
,由編譯器根據上下文決定選擇哪乙個。
作用:相同類的物件之間的 數值傳遞
應用地方:
1. 物件以值傳遞的方式傳入函式引數
(1).物件傳入形參時,會先會產生乙個相同類的臨時物件
(2).然後呼叫拷貝建構函式把物件的值給臨時物件。
(3).等函式執行完後, 析構掉臨時物件。
2.物件以值傳遞的方式從函式返回
cexample fun(){}
函式值返回時首先產生乙個臨時物件,然後拷貝構造將返回值給臨時物件,函式結束,析構掉臨時物件
3. 物件需要通過另外乙個物件進行初始化;
cexample b(100); //構造b物件
cexample a(b); 拷貝b到a
cexample a=b; 拷貝b到a
淺拷貝和深拷貝:
當類的建構函式裡面包括動態位址分配時候,拷貝建構函式要響應的新增動態位址分配的操作!!
在「深拷貝」的情況下,對於物件中動態成員,就不能僅僅簡單地賦值了,而應該重新動態分
配空間,如上面的例子就應該按照如下的方式進行處理:
[c-sharp]view plain
copy
class
rect
rect(const
rect& r)
~rect() // 析構函式,釋放動態分配的空間
} private
: int
width;
intheight;
int*p;
// 一指標成員
};
此時,在完成物件的複製後,記憶體的乙個大致情況如下:
此時rect1的p和rect2的p各自指向一段記憶體空間,但它們指向的空間具有相同的內容,這就是所謂
的「深拷貝」
拷貝建構函式,預設拷貝建構函式
拷貝建構函式,預設拷貝建構函式 1.c 的預設拷貝建構函式,從深度拷貝和淺拷貝說起 c 類的預設拷貝建構函式的弊端 c 類的中有兩個特殊的建構函式,1 無參建構函式,2 拷貝建構函式。它們的特殊之處在於 1 當類中沒有定義任何建構函式時,編譯器會預設提供乙個無參建構函式且其函式體為空 2 當類中沒有...
建構函式 拷貝建構函式
建構函式可以分為三類 1 不帶引數的建構函式 在函式體中對資料成員賦初值,這種方式使該類的每乙個物件都得到同一組初值 2 帶引數的建構函式 如果使用者希望對不同的物件賦不同的初值,可以採用帶引數的建構函式。在呼叫不同物件的建構函式時從外面將不同的資料傳遞給建構函式,以實現初始化 3 複製建構函式 建...
建構函式 拷貝建構函式
person person 引用就是指標常量 所以person p person const p,引用所以一旦初始化指向某個位址,就不能在改變了。為什麼前面還要加const,因為拷貝建構函式的目的就是將乙個物件的所有屬性拷貝到另外乙個物件,這個物件的屬性不變,加上const 相當於 const pe...