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