为什么C++中只有指针和引用才能实现多态?

本文通过一个C++示例程序详细解析了虚函数表的工作原理。解释了当使用基类指针指向派生类对象时,如何正确调用到派生类的虚函数。同时分析了对象赋值时基类成员与派生类特有成员的行为差异。

代码:

class A
{
public:
    virtual void Debug(){}
};

class B:public A
{
public:
   virtual void Debug(){}
};

void main()
{
    B b;
    A a = b;
    A * point_A = &b;
    
    a.Debug();
    point_A->Debug();
}

分析:

在程序中:a.Debug调用的是A::Debug,而point_A->Debug调用的是B::Debug。

——对于程序A a = b而言,b内存布局在赋值的时候已经从B转换到A了,多于的数据都被丢弃,因此其就是一个A类型变量,那么a.Debug这里的a就是一个A类型的变量。
——对于point_A来说,它是一个指针,其类型虽然是A,但指向的区域的内容却是一个B类型的内存结构,虽然内存结果的布局与A兼容,但其虚函数表中的Debug却是B的实现。

转载于:https://www.cnblogs.com/yedushusheng/p/5524039.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值