關(guān)于C++多重繼承下虛表結(jié)構(gòu)的問題
前言
昨天寫一個(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)這類問題,我們最后看下本例中的內(nèi)存結(jié)構(gòu):




到此這篇關(guān)于關(guān)于C++ 多重繼承下虛表結(jié)構(gòu)的問題的文章就介紹到這了,更多相關(guān)C++ 多重繼承虛表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C/C++?Qt?Tree與Tab組件實(shí)現(xiàn)分頁菜單功能
這篇文章主要介紹了C/C++?Qt?Tree與Tab組件實(shí)現(xiàn)分頁菜單功能,實(shí)現(xiàn)一個(gè)類似于樹形菜單欄的功能,當(dāng)用戶點(diǎn)擊菜單欄中的選項(xiàng)時(shí)則會(huì)跳轉(zhuǎn)到不同的頁面上,本文簡單給大家分享實(shí)現(xiàn)代碼,感興趣的朋友跟隨小編一起看看吧2021-11-11
詳解C/C++ Linux出錯(cuò)處理函數(shù)(strerror與perror)的使用
我們知道,系統(tǒng)函數(shù)調(diào)用不能保證每次都成功,必須進(jìn)行出錯(cuò)處理,這樣一方面可以保證程序邏輯正常,另一方面可以迅速得到故障信息。本文主要為大家介紹兩個(gè)出錯(cuò)處理函數(shù)(strerror、perror)的使用,需要的可以參考一下2023-01-01
C++實(shí)現(xiàn)簡易選課系統(tǒng)代碼分享
這篇文章主要介紹了C++實(shí)現(xiàn)簡易選課系統(tǒng)及實(shí)現(xiàn)代碼的分享,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望對(duì)你有所幫助2022-01-01
C/C++實(shí)現(xiàn)獲取硬盤序列號(hào)的示例代碼
獲取硬盤的序列號(hào)、型號(hào)和固件版本號(hào),此類功能通常用于做硬盤綁定或硬件驗(yàn)證操作,下面我們就來學(xué)習(xí)一下如何使用C/C++實(shí)現(xiàn)獲取硬盤序列號(hào)吧2023-11-11
C語言實(shí)現(xiàn)頁面置換 先進(jìn)先出算法(FIFO)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)頁面置換,先進(jìn)先出算法(FIFO),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12

