真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

C++中多態(tài)的實(shí)現(xiàn)原理是什么-創(chuàng)新互聯(lián)

這篇文章給大家介紹C++中多態(tài)的實(shí)現(xiàn)原理是什么,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

從事達(dá)州主機(jī)托管,服務(wù)器租用,云主機(jī),虛擬主機(jī),空間域名,CDN,網(wǎng)絡(luò)代維等服務(wù)。

1、說明


我們都知道多態(tài)指的是父類的指針在運(yùn)行中指向子類,那么它的實(shí)現(xiàn)原理是什么呢?答案是虛函數(shù)表

關(guān)于virtual 一文中,我們?cè)敿?xì)了解了C++多態(tài)的使用方式,我們知道沒有virtual 關(guān)鍵子就沒法使用多態(tài)

2、虛函數(shù)表

我們看一下下面的代碼

class A
{
public:
  int i;
  virtual void func() { cout << "A func" << endl; }
  virtual void func2() { cout << "A func2" << endl; }
  void func3() { cout << "A func3" << endl; }
};
class B : public A
{
  int j;
  void func() { cout << "B func" << endl; }
  void func3() { cout << "B func3" << endl; }
};
int main()
{
  cout << sizeof(A) << ", " << sizeof(B); //輸出 8,12
  return 0;
}

在32位編譯模式下,程序的運(yùn)行結(jié)果是:8,12

但是如果把代碼中的virtual 刪掉,則程序的運(yùn)行結(jié)果為:4,8

可以發(fā)現(xiàn),有了虛函數(shù)之后,類所占的存儲(chǔ)空間比沒有虛函數(shù)多了4個(gè)字節(jié),這個(gè)4個(gè)字節(jié)就是實(shí)現(xiàn)多態(tài)的關(guān)鍵 -- 位于對(duì)象存儲(chǔ)空間的最前端的指針,存放的是 虛函數(shù)表的地址,這個(gè)是由編譯器實(shí)現(xiàn)的

每個(gè)帶有虛函數(shù)的類(包括其子類)都有虛函數(shù)表

虛函數(shù)表中存放著虛函數(shù)的地址,注意是虛函數(shù)的地址,非虛函數(shù)不在此列

虛函數(shù)表是編譯器實(shí)現(xiàn)的,程序運(yùn)行時(shí)被載入內(nèi)存,一個(gè)類的虛函數(shù)表中列出了該類的全部虛函數(shù)地址。

例如,上面代碼中,類A的對(duì)象的存儲(chǔ)空間以及虛函數(shù)表如圖所示:

C++中多態(tài)的實(shí)現(xiàn)原理是什么

類B的對(duì)象的存儲(chǔ)空間以及虛函數(shù)表,如下圖所示:

C++中多態(tài)的實(shí)現(xiàn)原理是什么

多態(tài)的函數(shù)調(diào)用語句被編譯成根據(jù)基類指針?biāo)赶虻膶?duì)象中存放的虛函數(shù)表的地址,在虛函數(shù)表中查找虛函數(shù)地址,并調(diào)用虛函數(shù)的一系列指令

3、代碼示例

在上面代碼的基礎(chǔ)上

A* p = new B();
p->func();	//B func
p->func3();	//A func3
p->func2();	//A func

第二行代碼執(zhí)行如下:

  • 取出 p 指針?biāo)赶虻奈恢玫那?個(gè)字節(jié),即對(duì)象所屬的類(類B)的虛函數(shù)表的地址(64位編譯模式下是8個(gè)字節(jié));

  • 根據(jù)虛函數(shù)表的地址找到虛函數(shù)表,并在虛函數(shù)表中查找要調(diào)用的虛函數(shù)地址;

  • 調(diào)用虛函數(shù);

到此,我們應(yīng)該不難理解,上面第二行和第三行代碼執(zhí)行的分別是類A和類B的方法

執(zhí)行p->func(); 找的是類B虛函數(shù)表中 func() 地址,因?yàn)轭怋重寫了,所以保存的是類B的func()地址

而執(zhí)行p->func3(); 的時(shí)候,發(fā)現(xiàn) func3() 不是虛函數(shù),所以并沒有找虛函數(shù)列表,而是直接調(diào)用的p(類A類型)的方法

同樣的,執(zhí)行p->func2(); 的時(shí)候,找的也是類B的虛函數(shù)表,因?yàn)轭怋沒有重寫 func2,所以存的是類A的虛函數(shù) func2() 的地址,所以執(zhí)行了類A的 func2() 方法

關(guān)于C++中多態(tài)的實(shí)現(xiàn)原理是什么就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。


網(wǎng)站標(biāo)題:C++中多態(tài)的實(shí)現(xiàn)原理是什么-創(chuàng)新互聯(lián)
瀏覽路徑:http://weahome.cn/article/dpsppi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部