大多數C++書籍都說在我們沒有自己定義構造函數的時候,編譯器會自動生成默認構造函數。其實這句話我一直也是
深信不疑。但是最近看了一些資料讓我有了一點新的認識。
其實我覺得大多數C++書籍之所以這樣描述其實是玩了文字游戲的。如果說編譯器自動產生的默認構造函數對于我們
的類沒有任何作用,也就是說在編譯器默認生成的這個構造函數里根本沒有任何實質性的代碼工作,那么這種默認構
造其實是可有可無的,所以不妨說編譯器其實是為每個類生成了默認構造函數的。
在深度探索C++對象模型中講了四種關于編譯器自動生成默認構造函數的情況,在這四種情況下生成的默認構
造函數里面是由實質的隱含代碼操作的:
1、 如果類A成員中含有某個類B的對象,恰好類B也顯示定義了構造函數,那么在產生類A對象的時候編譯器會產生一個默認構造函數,在這個默認構造函數中提供了調用類A構造函數的代碼。
2、如果類B繼承于類A,且類A顯示定義了構造函數,那么在生成類B對象的過程中編譯器同樣會產生一個默認構造函數,在這個構造函數中提供調用基類A構造函數的代碼。
3、如果某個類含有虛函數,那么編譯器會自動產生一個默認構造函數以提供虛表指針相關的初始化操作。
4、如果一個類虛繼承于其他類,那么同樣的編譯器會為該類產生默認的構造函數。
除以上四種情況,編譯器都不產生默認構造函數,因為就算編譯器產生了默認構造函數,然而在該默認構造函數中沒有實質的內容,那么這個默認構造函數也就是沒存在的意義的,那么我們說編譯器不產生也無妨吧。
以上就是小編為大家帶來的對C++默認構造函數的一點重要說明全部內容了,希望大家多多支持VEVB武林網~
新聞熱點
疑難解答