首先,我寫了一個構造函數用virtual修飾的類A,代碼如下:
class A { public: virtual A() {} };
運行結果:(我是在VS下運行的)
可以看出這樣的代碼編譯時是有問題的。
爲什麼構造函數不能是虛函數呢?
這裏你需要知道一個概念,那就是虛函數表vtbl,每一個擁有虛成員函數的類都有一個指向虛函數表的指針。對象通過虛函數表裏存儲的虛函數地址來調用虛函數。
那虛函數表指針是什麼時候初始化的呢?當然是構造函數。當我們通過new來創建一個對象的時候,第一步是申請需要的內存,第二步就是調用構造函數。試想,如果構造函數是虛函數,那必然需要通過vtbl來找到虛構造函數的入口地址,顯然,我們申請的內存還沒有做任何初始化,不可能有vtbl的。因此,構造函數不能是虛函數。