C++虚函数学习总结

  • 时间:
  • 浏览:
  • 来源:互联网

一、虚函数学习

1.什么是虚函数?

本质不是重载而是覆盖。

2.虚函数有什么作用?

实现多态。同一个声明的不同实现。

3.子类重写父类的普通函数和子类重写父类的虚函数有什么区别?

可以让成员函数的操作一般化,用基类的指针指向不同的派生类对象时,基类指针调用其虚函数成员函数,则会调用其真正指向对象的成员函数,而不是基类中定义的成员函数(只要派生类改写了该成员函数)

若不是虚函数,则不管基类指针指向的哪个派生类的对象,调用时都会调用基类中定义的哪个函数。

个人理解:就像论文初稿(基类),一稿、二稿、三稿(三个派生类),如果初稿没有定义为虚函数那么访问一稿二稿三稿的时候只能看到初稿,但是如果定义为虚函数,只要派生类重写了虚函数,就想看哪个稿子都可以。

4.应用场景

4.1 开发中会使用框架,开发人员无法对框架中的函数进行修改。对基类中的函数进重写之后有的函数是用框架调用的。不使用虚函数则只能使用原框架中的函数,使用虚函数后则实现多态,能自己定义符合自己使用场景的函数。

4.2

二、其他问题总结

1.纯虚函数。

基类中只声明虚函数但是不实现,要求在子类中必须实现。

定义方法:virtual Functiontype FunctionName()=0;

和虚函数的区别是虚函数在基类中实现了的,子类进行覆盖。

2.C++的多态性

编译时多态性:通过重载函数实现
运行时多态性:通过虚函数实现

要实现多态需要:一是公有继承、二是虚函数。

3.虚函数调用方式

通过基类的指针或引用。根据指针指向不同的对象决定调用哪个函数。

三、其他知识点总结

1.虚函数是动态绑定的基础。是非静态的成员函数。

2.virtual只能在声明的时候使用,实现的时候不能加。

3.具有继承性。基类中声明的虚函数在派生类中无论是否说明,同原型函数都自动为虚函数。

4.虚继承(不推荐,别用)

为了解决多重继承而实现的。若D直接继承B1、B2则A中的参数会在B中出现两次,浪费空间。使用虚继承则会节省空间。

class A;

class B1: public virtual A;

class B2: public virtual A;

class D: public B1, public B2;

四、show me code

#include<iostream>
using namespace std;
class A{
    public:
    virtual void foo()
    {
        cout<<"A'foo"<<endl;
        bar();
    }
    virtual void bar()
    {
        cout<<"A's bar"<<endl;
    }
};
class B: public A{
    public:
    virtual void foo()
    {
        cout<<"B'foo"<<endl;
        A::foo();
    }
    virtual void bar()
    {
        cout<<"B's bar"<<endl;
    }
};
int main()
{
    B bobj;
    A *aptr=&bobj;//
    aptr->foo();
    A aobj=*aptr;
    aobj.foo();
}
/*
aptr->foo()输出结果是:
   B's foo()//这个明白,多态性
   A's foo()//这个也明白,执行A::foo();
   B's bar()// 虽然调用的是这个函数:A::foo(); 但隐式传入的还是bobj 的地址,所以再次调用bar();调用时还是会调用B的函数, 与虚函数指针有关

aobj.foo()输出结果是:
  A's foo() // 这个不是指针,aobj完全是一个A的对象,与多态没有关系
  A's bar() 
*/

本文链接http://element-ui.cn/article/show-218955.aspx