C++多繼承多態(tài)的實例詳解
C++多繼承多態(tài)的實現(xiàn)
如果一個類中存在虛函數,在聲明類的對象時,編譯器就會給該對象生成一個虛函數指針,該虛函數指針指向該類對應的虛函數表。
多態(tài)的實現(xiàn)是因為使用了一種動態(tài)綁定的機制,在編譯期間不確定調用函數的地址,在調用虛函數的時候,去查詢虛函數指針所指向的虛函數表。
派生類生成的對象中的虛函數指針指向的是派生類的虛函數表,因此無論是基類還是派生來調用,都是查詢的是派生類的表,調用的是派生類的函數。
如果發(fā)生了多繼承,多個基類中都有虛函數,那么該是怎樣的呢?虛函數指針如何排列,多個基類的指針為什么能夠同時指向派生類對象,同時發(fā)生多態(tài)?
請看下面這段程序
#include <stdio.h>
#include <iostream>
using namespace std;
class Base1{
public:
void fun()
{
printf("this is Base1 fun\n");
}
virtual void fun1()
{
printf("this is Base1 fun1\n");
}
};
class Base2{
public:
void fun()
{
printf("this is Base2 fun\n");
}
virtual void fun2()
{
printf("this is Base2 fun1\n");
}
};
class Derived : public Base1,public Base2{
public:
void fun()
{
printf("this is Derived fun\n");
}
void fun1()
{
printf("this is Derived fun1\n");
}
void fun2()
{
printf("this is Derived fun2\n");
}
};
int main()
{
Derived *pd = new Derived();
Base1 *p1 = (Base1 *)pd;
Base2 *p2 = (Base2 *)pd;
p1->fun();
p2->fun();
p1->fun1();
p2->fun2();
printf("Base1 p1:%x\n", p1);
printf("Base2 p2:%x\n", p2);
return 0;
}
運行結果如下
feng@mint ~/code/c++/cpp_muti_drived $ ./muti_derived this is Base1 fun this is Base2 fun this is Derived fun1 this is Derived fun2 Base1 p1:2097c20 Base2 p2:2097c28
Derived類分別繼承了Base1和Base2,根據結果來看,均發(fā)生了多態(tài)?;愔羔樥{用函數,調用的均是派生類的對象。
通過打印出了p1和p2的地址,發(fā)現(xiàn)他們相差了8個字節(jié),就能明白了,在做類型轉換的過程中,如果把地址傳給第二個基類的指針的時候會自動把地址減去8,在64位系統(tǒng)下,剛好是一個指針的長度。因此p2指向的實際上是第二個虛函數指針的地址,這樣,就能夠實現(xiàn)多繼承的多態(tài)了。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
VC++實現(xiàn)CStdioFile寫入及讀取文件并自動換行的方法
這篇文章主要介紹了VC++實現(xiàn)CStdioFile寫入及讀取文件并自動換行的方法,很實用的功能,需要的朋友可以參考下2014-08-08
實戰(zhàn)開發(fā)為單片機的按鍵加一個鎖防止多次觸發(fā)的細節(jié)
今天小編就為大家分享一篇關于實戰(zhàn)開發(fā)為單片機的按鍵加一個鎖防止多次觸發(fā)的細節(jié),小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12

