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