自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

探秘C++虛函數(shù):解密多態(tài)的奧秘

開(kāi)發(fā) 前端
虛函數(shù)—作為面向?qū)ο缶幊痰暮诵奶匦灾?,虛函?shù)不僅在代碼中發(fā)揮著重要作用,更是實(shí)現(xiàn)多態(tài)性的關(guān)鍵所在。

虛函數(shù)—作為面向?qū)ο缶幊痰暮诵奶匦灾?,虛函?shù)不僅在代碼中發(fā)揮著重要作用,更是實(shí)現(xiàn)多態(tài)性的關(guān)鍵所在。

什么是虛函數(shù)?

在 C++ 中,虛函數(shù)是為了實(shí)現(xiàn)運(yùn)行時(shí)多態(tài)性而設(shè)計(jì)的特殊類(lèi)型的函數(shù)。通過(guò)在基類(lèi)中聲明虛函數(shù),并在派生類(lèi)中進(jìn)行重寫(xiě),可以在程序運(yùn)行時(shí)根據(jù)實(shí)際對(duì)象類(lèi)型確定調(diào)用的函數(shù)版本。這為我們提供了一種靈活的方式來(lái)處理繼承關(guān)系,使得代碼更具可擴(kuò)展性和可維護(hù)性。

虛函數(shù)表的作用

虛函數(shù)表(virtual function table,簡(jiǎn)稱(chēng) Vtable)是 實(shí)現(xiàn)虛函數(shù)的重要機(jī)制之一。每個(gè)類(lèi)(包括含有虛函數(shù)的類(lèi))都會(huì)生成一個(gè)對(duì)應(yīng)的虛函數(shù)表,其中存儲(chǔ)了該類(lèi)中所有虛函數(shù)的地址。

當(dāng)對(duì)象被創(chuàng)建時(shí),會(huì)分配一個(gè)指向其類(lèi)的虛函數(shù)表的指針(虛指針)。通過(guò)這個(gè)指針,程序能夠在運(yùn)行時(shí)確定調(diào)用的函數(shù)版本,實(shí)現(xiàn)了動(dòng)態(tài)綁定。注意與靜態(tài)綁定混淆重載-靜態(tài)綁定(鏈接)。

虛函數(shù)表的性質(zhì)

  • 每個(gè)類(lèi)都有自己的虛函數(shù)表:當(dāng)一個(gè)類(lèi)中包含至少一個(gè)虛函數(shù)時(shí),編譯器會(huì)為該類(lèi)生成一個(gè)虛函數(shù)表。 
  • 虛函數(shù)表中存儲(chǔ)的是函數(shù)指針:虛函數(shù)表中的每個(gè)條目都是一個(gè)指向?qū)?yīng)虛函數(shù)的函數(shù)指針。 
  • 對(duì)象含有指向其類(lèi)的虛函數(shù)表的指針:每個(gè)對(duì)象都含有一個(gè)指向其類(lèi)的虛函數(shù)表的指針,通過(guò)這個(gè)指針實(shí)現(xiàn)動(dòng)態(tài)綁定。 

派生類(lèi)的虛函數(shù)表包含基類(lèi)的虛函數(shù)表內(nèi)容,并擴(kuò)展新函數(shù):派生類(lèi)的虛函數(shù)表通常是在基類(lèi)的虛函數(shù)表的基礎(chǔ)上進(jìn)行擴(kuò)展的。 

示例代碼解釋 讓我們通過(guò)一段簡(jiǎn)單的代碼來(lái)說(shuō)明虛函數(shù)表的工作原理:

#include <iostream>

class Base {
public:
    virtual void func1() {
        std::cout << "Base::func1()" << std::endl;
    }
    virtual void func2() {
        std::cout << "Base::func2()" << std::endl;
    }
};

class Derived : public Base {
public:
    void func1() override {
        std::cout << "Derived::func1()" << std::endl;
    }
    void func3() {
        std::cout << "Derived::func3()" << std::endl;
    }
};

int main() {
    Base* ptr = new Derived();
    ptr->func1(); // 動(dòng)態(tài)綁定
    ptr->func2(); // 動(dòng)態(tài)綁定
    delete ptr;
    return 0;
}

在這個(gè)示例中,我們創(chuàng)建了一個(gè)基類(lèi) Base 和一個(gè)派生類(lèi) Derived,后者重寫(xiě)了基類(lèi)中的 func1()。

在 main() 函數(shù)中,我們創(chuàng)建了一個(gè)基類(lèi)指針指向派生類(lèi)對(duì)象,并通過(guò)該指針調(diào)用了兩個(gè)虛函數(shù) func1() 和 func2()。由于 func1() 是虛函數(shù),并且對(duì)象是 Derived 類(lèi)型,所以會(huì)動(dòng)態(tài)綁定到 Derived::func1()。而 func2() 在派生類(lèi)中沒(méi)有被重寫(xiě),所以會(huì)綁定到基類(lèi)的版本。

虛函數(shù)表的大小

先看一個(gè)例子(操作環(huán)境64位系統(tǒng))

//先看空類(lèi)大小
class test {

};
//只有一個(gè)虛函數(shù)的類(lèi)大小
class test1 
{
  public:
    virtual void function()
{
    std::cout << "function()" << std::endl;
    }
};
//兩個(gè)虛函數(shù)類(lèi)的大小
class test2 
{
  public:
    virtual void function1()
{
    std::cout << "function1()" << std::endl;
    }
    
    virtual void function2()
{
    std::cout << "function2()" << std::endl;
    }
};

int main()
{
  std::cout<<"sizeof test: "<<sizeof(test)<<std::endl;
  std::cout<<"sizeof test1: "<<sizeof(test1)<<std::endl;
  std::cout<<"sizeof test2: "<<sizeof(test2)<<std::endl;
  return 0;
}

類(lèi)在內(nèi)存中記錄虛函數(shù)是以一個(gè)指針記錄的,并且該指針指向一個(gè)數(shù)組,數(shù)組中裝著的是虛函數(shù)的地址。同時(shí),經(jīng)過(guò)實(shí)驗(yàn),64bit的編譯器下,虛函數(shù)表的指針大小是8字節(jié)。

責(zé)任編輯:趙寧寧 來(lái)源: AI讓生活更美好
相關(guān)推薦

2024-01-23 10:13:57

C++虛函數(shù)

2010-01-18 17:38:54

C++虛函數(shù)表

2010-02-01 11:22:09

C++虛函數(shù)

2022-07-18 15:32:37

C++虛函數(shù)表

2024-12-17 12:00:00

C++對(duì)象模型

2011-05-24 16:20:27

虛函數(shù)

2010-01-28 16:16:32

C++多態(tài)性

2010-01-15 10:22:24

C++語(yǔ)言

2010-01-20 18:06:06

C++虛基類(lèi)

2011-07-15 00:47:13

C++多態(tài)

2010-01-27 10:36:54

C++虛函數(shù)

2011-05-24 16:30:35

虛函數(shù)

2024-12-19 14:42:15

C++內(nèi)存泄漏內(nèi)存管理

2010-02-05 13:35:19

C++虛析構(gòu)函數(shù)

2010-02-01 14:07:12

C++多態(tài)性

2011-04-06 08:57:07

C++java多態(tài)

2011-07-20 17:04:55

C++虛函數(shù)動(dòng)態(tài)聯(lián)編

2010-01-13 18:52:20

Visual C++

2010-01-13 18:49:54

C++的復(fù)雜性

2010-02-03 10:50:33

C++多態(tài)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)