當自定義的類中沒有定義拷貝構造函數是,編譯器會自動為這個類創建一個。
例如在類 A 中
class A
{
}
編譯器會為它創建一個拷貝構造函數(當然不只創建這一個函數另外還有缺省構造、析構函數(一般是非虛的)、&重載、const & 重載、=重載)。
class A
{
A(const A& a)
{
...
}
}
編譯器首先檢測該類中有沒有此構造函數如有的話則編譯器不做處理,若沒有則創建。
自動創建的函數里的工作就是對該類中的非靜態變量進行逐一拷貝。
在對象在執行拷貝的時候則調用該函數,若類 A 為一個派生類,那么該規則適合于每一層父類。
當類 A 中有 string 成員的時候,編譯器會調用 string 的拷貝函數,當成員變量沒有拷貝函數時,例如 int 類型,那么它將拷貝每一個比特位來進行初始化。
當類中有個成員變量是引用的時候,比如是 string & 的時候,編譯器會為它生成賦值運算符的函數嗎?我們可以來提編譯器考慮一下:加入是可以生成那該如何去做,引用本身能夠被改變嗎?換句話說就是將它指向改變,不能,引用是很專一的。那將引用指向的內容改變?如果改變了,那么指向這塊內存的所有指針和引用都會受到影響,后果將是無法想象的。兩種方式都不行,怎么辦?惹不起還躲不起嗎,我不干了。于是編譯器就不去生成這個賦值函數了,那么這個函數就需要程序員自己來實現。