c++多态的实现原理

  c++多态的实现,依靠的是虚函数表。先来看看代码:

#include <iostream>
using namespace std;

class TestCls
{
public:
    int a;

    void func()
    {
        cout << "hello" << endl;
    }
};

int main(void)
{
    cout << "sizeof(TestCls) = " << sizeof(TestCls) << endl;
    return 0;
}

  代码的意图是要求出类TestCls占据空间的大小,编译运行结果:
这里写图片描述
  在类中,成员函数是位于代码段的,所以不算在类TestCls占据空间的大小中,其大小等于成员变量a的大小。

  如果把func()函数声明为虚函数后,

virtual int func()
{
    //...
}

  编译运行:
这里写图片描述

  可见多了4字节空间,这4字节正是用于保存虚函数表的地址的。虚函数表是一个存储虚成员函数地址的数据结构,它由编译器自动生成与维护。注意,只有在类中存在虚函数,虚函数才会存在与类中。

class TestCls
{
public:
    int a;

    virtual void func()
    {
        cout << "hello" << endl;
    }
};

class SubTestCls : public TestCls
{
public:
    void func()
    {
        cout << "world" << endl;
    }
};

void print(TestCls *t)
{
    t->func();
}

int main(void)
{
    TestCls t1;
    SubTestCls st;

    print(&t1);

    print(&st);

    return 0;
}

  如上,当print函数中的形参t指向的父类对象t1的地址时:
这里写图片描述

  编译器先判断func()函数是否为虚函数:
  1. 若为虚函数,编译器会通过对象中的虚函数的指针找到虚函数表,在该该表中查找func()函数,进而调用。
  2. 若不为虚函数,编译器直接通过对象确定被调用成员函数的地址,进而调用。

当print函数中的形参t指向的子类类对象st的地址时,同理:
这里写图片描述

  综上,从程序执行效率上看,虚函数的效率低于普通成员函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值