一、抽象类的定义
包含纯虚函数的类称为抽象类,而且抽象类不能实例化对象。(不能是实例化为具体的类)
纯虚函数:在虚函数后面写上=0;
例如:
class Person
{
public:
virtual void test() = 0;//纯虚函数
};
class Student : public Person
{
public:
virtual void test()
{
cout << "~Person()" << endl;
}
};
派生类继承后也不能实例化出对象,只有重写纯虚函数,派生类才能实例化出对象。
纯虚函数一般用在基础的基类中,这些基类一般不需要定义对象,在设计框架中用的比较多。
普通函数与虚函数的区别:
普通函数的继承是一种实现继承,派生类继承了基类函数,可以使用函数,继承的是函数的实现。
虚函数的继承是一种接口继承,派生类继承的是基类虚函数的接口,目的是为了重写,达成多态,继承的是接口。
二、虚函数表
虚函数表简称为虚表,虚表的作用是存放虚函数指针,普通函数指针不会存放在虚表中。
只要存在虚函数就会产生虚表,基类中的虚表中存放基类的虚函数指针,派生类的虚表中存放派生类的虚函数指针;若派生类中的函数对基类中的函数产生重写操作,此时派生类继承基类后,虚表中只会存在派生类中的虚函数指针,将基类中的虚函数指针覆盖。
以以下代码为例
class Base
{
public:
virtual void Func1()
{
cout << "This is Base::Func1" << endl;
}
virtual void Func2()
{
cout<<"This is Base::Func2" << endl;
}
void Func3()
{
cout<<"This is Base::Func3" << endl;
}
};
class TestBase : public Base
{
public:
virtual void Func1()
{
cout << "This is TestBase::Func1" << endl;
}
};
由上图可以看出派生类的虚表中存放的是派生类的Func1()函数指针,而不是基类中Func1()函数指针,原因是派生类对基类中的Func1()进行了重写。