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