C++继承时虚函数、纯虚函数和成员函数

本文深入探讨了C++中的虚函数和纯虚函数概念,解释了它们如何实现运行时多态,并通过实例展示了普通函数、虚函数及纯虚函数在继承中的行为差异。此外,文章还讨论了有效使用C++的建议,避免重定义非虚继承函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这几天看书看的时候没什么感觉,面试起来就比较懵逼,感觉之前的所有东西都杂糅在一起,感觉就比较乱。用一篇博客记录一下。

原博客地址:https://www.cnblogs.com/xupeidong/p/9519386.html

虚函数:

C++的虚函数主要作用是“运行时多态”,父类中提供虚函数的实现,为子类提供默认的函数实现。子类可以重写父类的虚函数实现子类的特殊化。

纯虚函数:

  • C++中包含纯虚函数的类,被称为是“抽象类”。抽象类不能使用new出对象,只有实现了这个纯虚函数的子类才能new出对象。
  • C++中的纯虚函数更像是“只提供申明,没有实现”,是对子类的约束,是“接口继承”。
  • C++中的纯虚函数也是一种“运行时多态”。

普通函数

普通函数是静态编译的,没有运行时多态,只会根据指针或引用的“字面值”类对象,调用自己的普通函数。

普通函数是父类为子类提供的“强制实现”。

因此,在继承关系中,子类不应该重写父类的普通函数,因为函数的调用至于类对象的字面值有关。

一个实例

#include <iostream>
using namespace std;

class A
{
public:
    virtual void out1()=0;  ///由子类实现
    virtual ~A(){};
    virtual void out2() ///默认实现
    {
        cout<<"A(out2)"<<endl;
    }
    void out3() ///强制实现
    {
        cout<<"A(out3)"<<endl;
    }
};

class B:public A
{
public:
    virtual ~B(){};
    void out1()
    {
        cout<<"B(out1)"<<endl;
    }
    void out2()
    {
        cout<<"B(out2)"<<endl;
    }
    void out3()
    {
        cout<<"B(out3)"<<endl;
    }
};

int main()
{
    A *ab=new B;
    ab->out1();
    ab->out2();
    ab->out3();
    cout<<"************************"<<endl;
    B *bb=new B;
    bb->out1();
    bb->out2();
    bb->out3();

    delete ab;
    delete bb;
    return 0;
}

运行结果:
在这里插入图片描述

总结

因为继承最主要的场景就是有多个类用的接口基本上一样,那么就需要一个抽象类,如果这个抽象类全是纯虚函数,

那么子类需要全部继承并且定义,这样带来的问题就是可能有的类不需要这个接口但是还必须写上且空定义,这样很累,

那就需要一部分虚函数接口,所以根据实际情况,组合纯虚函数和虚函数来使用。

还有Effective C++给我们的一个建议(或者叫警告?:千万不要声明重新定义继程而来的non-vritual函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值