簡述C++中虛擬函數(shù)的內(nèi)存分配機制
因為虛擬函數(shù)的地址翻譯取決于對象的內(nèi)存地址,而不取決于數(shù)據(jù)類型(編譯器對函數(shù)
調(diào)用的合法性檢查取決于數(shù)據(jù)類型)。原來,如果類中定義了虛擬函數(shù),該類及其派生類
就要生成一張?zhí)摵瘮?shù)表,即vtable。而在類的對象地址空間中存儲一個該虛函數(shù)表的入口,
占4個字節(jié),這個入口地址是在構(gòu)造對象是由編譯器寫入的。
有如下C++程序:
//#include<stdio.h>
#include<iostream>
using namespace std;
class CMem
{
public:
CMem(){}
public:
int m_first;
private:
unsigned char m_second;
public :
void fun1();
virtual int funOver(){return 1;}
};
class CMemSub : public CMem
{
public:
CMemSub(){}
public:
int m_three;
private:
int m_four;
public:
void fun3();
virtual int funOver(){return 2;}
virtual int fun4(){return 3;}
};
int main()
{
CMem a,*pMem;
CMemSub b;
pMem = &a;
printf("%d/n",pMem->funOver());
pMem = &b;
printf("%d/n",pMem->funOver());
return 0;
}
程序運行結(jié)果為:
1
2
這里涉及到虛函數(shù)的工作機制,由于對象的內(nèi)存空間中包含了虛函數(shù)表的入口,
編譯器能夠由這個入口找到適當?shù)奶摵瘮?shù),這個函數(shù)的地址不再由數(shù)據(jù)類型決定了。
語句pMem = &b;使pMem指向?qū)ο骲的內(nèi)存空間,調(diào)用pMem->funOver()時,
編譯器得到了對象b的vtable入口,并由這個入口找到了CMemSub::funOver()虛函數(shù)地址。到此,虛函數(shù)的秘密終于大白于天下了。虛函數(shù)是C++語法的重點和難點。
以上就是簡述C++中虛擬函數(shù)的內(nèi)存分配機制的詳細內(nèi)容,更多關于c++虛擬函數(shù)的資料請關注腳本之家其它相關文章!

