C/Cpp / C++ 构造函数和析构函数可以是虚函数吗
生活随笔
收集整理的這篇文章主要介紹了
C/Cpp / C++ 构造函数和析构函数可以是虚函数吗
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
答案
構造函數不可以是虛函數,而析構函數可以且常常是虛函數。
原因
1、構造函數不可以是虛函數
當類中聲明虛函數時,編譯器會在類中生成一個虛函數表,虛函數表是一個存儲成員函數指針的數據結構。
虛函數表是由編譯器自動生成與維護的,virtual成員函數會被編譯器放入虛函數表中,當存在虛函數時,每個對象都有一個指向虛函數的指針(vptr指針)。在實現多態的過程中,父類和派生類都有vptr指針。
vptr的初始化:當對象在創建時,由編譯器對 vptr 指針進行初始化。在定義子類對象時,vptr 先指向父類的虛函數表,在父類構造完成之后,子類的 vptr 才指向自己的虛函數表。
如果構造函數時虛函數,那么調用構造函數就需要去找vptr,而此時 vptr 還沒有初始化。
因此,構造函數不可以是虛函數。
2、析構函數常常是虛函數
與構造函數不同,vptr 已經完成初始化,析構函數可以聲明為虛函數,且類有繼承時,析構函數常常必須為虛函數。
比如下面的例子:
#include <iostream> using namespace std;class base { public:base(){cout << "base constructor" << endl;}virtual ~base(){cout << "base destructor" << endl;} };class derived : public base { public:derived(){cout << "derived constructor" << endl;}virtual ~derived(){cout << "derived destructor" << endl;} };int main() {base *pBase = new derived;cout << "---" << endl;delete pBase;return 0; }運行結果為:
若析構函數不是虛函數,則運行結果為:
可以看出:
- 若析構函數是虛函數,delete 時,基類和子類都會被釋放;
- 若析構函數不是虛函數,delete 時,只有基類會被釋放,而子類沒有釋放,存在內存泄漏的隱患。
詳情請看這里。
?
轉載于:https://zhuanlan.zhihu.com/p/255274039
?
(SAW:Game Over!)
總結
以上是生活随笔為你收集整理的C/Cpp / C++ 构造函数和析构函数可以是虚函数吗的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C/Cpp / 模板类中可以使用虚函数吗
- 下一篇: Http / Get 和 Post 区别