C++构造函数与析构函数中调用虚函数

在基类和派生类的构造函数和析构函数中调用虚函数,会不会体现出多态性呢?Jungle做了以下测试:

  1. 首先定义了基类Base和虚函数fun,并在构造函数和析构函数中调用了fun();
  2. 然后定义了派生类Derived1继承了Base,并重写了虚函数fun(),并在Derived的构造函数和析构函数中调用了fun();
  3. 接下里测试。
class Base {
public:
    Base()
    { 
        cout<<"Base::Base()"<<endl;
        fun();
    }
    virtual ~Base()
    {
        cout<<"Base::~Base()"<<endl;
        fun();
    }
    virtual void  fun()
    {
        cout<<"Base::fun() virtual"<<endl;
    }

};
class Derived1:public Base
{
public:
    Derived1()
    {
        cout<<"Derived1::Derived1()"<<endl;
        fun();;
    }
    ~Derived1()
    {
        cout<<"Derived1::~Derived1()"<<endl;
        fun();
    }
    virtual void fun()
    {
        cout<<"Derived1::fun() virtual"<<endl;
    }
};

int main()
{
    Base *b = new Base();
    delete b;
    cout<<endl;

    Derived1 *d = new Derived1();
    delete d;
    cout<<endl;

    Base *bd = new Derived1();
    delete bd;
    cout<<endl;

    system("pause");
    return 0;
}

这里写图片描述
结果分为三段,第一段不必说明。
第二段,Derived1 *d = new Derived1();时,先调用类构造函数,并且fun()是基类的fun(),因为此时派生类还不存在。然后才构造派生类。析构时,先析构派生类,并调用派生类的fun(),再析构基类。
第三段,基类指针指向派生类对象。构造时,先调用基类的构造函数,此时构造函数中调用了fun(),可以看到,这个fun是基类的fun(),这里“虚函数的动态绑定机制并没有会生效”,这是因为此时派生类还不存在。析构时,先析构派生类,派生类中的fun()调用的是自己的fun(),然后析构基类,基类析构函数中的fun()调用的是基类的fun(),这里“虚函数的动态绑定机制也没有会生效”,这是因为此时派生类已经不存在了

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冯Jungle

您的支持是对我最大的鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值