C++中虚函数和纯虚函数的个人理解

1.目的

我们为什么要使用到虚函数或者纯虚函数呢?首先,虚函数是为了可以让基类的指针来调用子类的方法,而纯虚函数则是给你一个接口,让你自己在子类里面去实现这个方法。

举个例子,如果我们想定义一个动物类,那么,动物类(a)就是基类。老虎类(t)就是继承动物类的子类,动物类中有eat()这个虚函数,我们可以通过A *a = new T();来实例化一个指针a,但是它调用的是老虎类中的eat()方法;

那么纯虚函数有什么用呢,当动物类中有一个方法,比如说eat(),但是我们要实现,不同的动物吃不同的东西,我们就可以把这个eat()函数来定义为一个纯虚函数,从而让这个方法在子类中得到重写,以此来实现多态。

2.实例

虚函数

class A
{
public:
    virtule void eat()
    {
        cout<<"a can eat anything~";
    }
};

class T : public A
{
public:
    void eat()
    {
        cout<<"tiger can eat meat~";
    }
};

int main()
{
    A *a = new T();
    a -> eat();
    return 0;
}

上面这段代码就是虚函数的调用,虽然说我们定义一个类A的指针,但是这个指针a最终去调用的方法还是调用的T类中的方法。

纯虚函数  

class A
{
    public :
        virtual void eat() = 0;
};

class T : public A
{
    public :
        void eat()
            {
                cout<<"tiger can eat much meat~";
            } 
};


int main()
{
    T *tiger;
    A *a;
    a->eat();//编译报错,类A作为抽象类不可以进行实例化
    tiger->eat();//调用T类中的方法
}

 小结:

1.不管是虚函数还是纯虚函数,都是为了去实现“动态多态”,什么是动态多态和静态多态呢,不负责任地说一句,我认为,像函数重载这样的就是静态多态,编译的时候就已经确认了多态属性;但是像虚函数这种的,编译的时候不去管,只有在真正运行的时候才会去关注;

2.那虚函数和纯虚函数到底有什么区别呢?虚函数就是为了让基类中的指针来调用不同派生类中的方法,属于是向外扩展这个类的作用范围(也许这么形容不太贴切);但是纯虚函数呢,就是为了去约束子类的行为,纯虚函数会告诉子类,你继承我,你必须要给我实现出来,否则你也和我一样,还是个抽象类。当然,实现出来的功能依然是由子类来决定的。属于是,约束这个方法。

3.虚函数的方法必须要在子类里面实现,否则就会报错,但是纯虚函数的方法就不需要在子类里面去实现,它可以在派生类里面去实现,派生类也不去实现的话,派生类也会变成一个抽象类,不可以被实例化。

4.虚函数的调用是通过一个虚函数表来进行实现的,但是那个表比较复杂,我也没看懂,目前为止这些知识只是知道他们是做什么用的,还没有用过。(手动哭笑)

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值