前言
昨天寫一個項目時遇到一個很詭異的現(xiàn)象 如下代碼所示:
class ParentA {
public :
int a=0x123456;
virtual void vFunParentA(){
std::cout << "vFunParentA" << std::endl;
}
};
class ParentB {
public:
int b = 0x456;
virtual void vFunParentB() {
std::cout<<"vFunParentB"<<std::endl;
int i = 0;
}
};
class Child:public ParentA,public ParentB {
int c = 0x789;
};
int main()
{
//注意這里使用void*
void* pChild = new Child;
//強轉(zhuǎn)
ParentB* pParentB = (ParentB*)pChild;
//強轉(zhuǎn)
ParentA* pParentA = (ParentA*)pChild;
pParentB->vFunParentB();
pParentA->vFunParentA();
getchar();
}
現(xiàn)在執(zhí)行后我們的預期輸出為
vFunParentB
vFunParentA
但實際輸出:
vFunParentA
vFunParentA
當時百思不得其“姐”,最后發(fā)現(xiàn)是自己對多重繼承下的虛表內(nèi)存結(jié)構(gòu)不夠了解。
博主另一外一篇關(guān)于虛表的:
c-15 c++虛表
在多重繼承下Child
內(nèi)存結(jié)構(gòu)應該是如下結(jié)構(gòu):
由于我們使用 void *
類型強轉(zhuǎn)為ParentB
,ParentA
返回的指針地址依然是ParentA
,而沒有做內(nèi)存偏移計算.如下圖所示:
當我們不適用void*
強轉(zhuǎn)后編譯器會幫我進行偏移計算會迫使ParentB
偏移8字節(jié),從而使pParentB
指向正確的內(nèi)存虛表。
在單一繼承下不會出現(xiàn)這類問題,我們最后看下本例中的內(nèi)存結(jié)構(gòu):
到此這篇關(guān)于關(guān)于C++ 多重繼承下虛表結(jié)構(gòu)的問題的文章就介紹到這了,更多相關(guān)C++ 多重繼承虛表內(nèi)容請搜索html5模板網(wǎng)以前的文章希望大家以后多多支持html5模板網(wǎng)!
【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!