3.2静态关联与动态关联
关联:确定调用的具体对象的过程。(指把一个函数名和一个类对象捆绑在一起,建立关联)。
静态关联:在编译时即可确定其调用的虚函数属于哪一个类,例如函数重载和通过对象名调用的虚函数。
由于是在运行前进行关联的,又称为早期关联。
动态关联:编译系统把他放在运行阶段进行处理,在运行阶段确定关联关系。也叫滞后关联。
3.3 在什么情况下应当声明虚函数
使用虚函数的注意:
1)只能用virtual声明类的成员函数,把它作为虚函数,而不能将类外的普通函数声明为虚函数。因为虚函数的作用是允许在派生类对象中对基类的虚函数重新定义。只能用于类的继承层次中。
2)一个成员函数声明为虚函数后,在同一类族中的类就不能再定义一个非virtual的但与该虚函数具有相同的参数(个数和类型)和函数返回值类型的同名函数。
在什么情况下将一个成员函数声明为虚函数?
1)首先看成员函数所在的类是否会作为基类,然后看成员函数在类的继承后有无可能被更改功能。
2)如果是通过基类指针或引用去访问的成员函数,应当声明为虚函数。
3)有时,定义虚函数时,并不定义其函数体,即函数体是空的。它的作用是定义了一个虚函数名,具体功能留给派生类去添加。
3.4虚析构函数
如果用new运算符建立了临时对象,若基类中有析构函数,并且定义了一个指向该基类的指针变量。在程序用带指针参数的delete运算符撤销对象时,系统只会执行基类的析构函数,而不执行派生类的析构函数。如下例
#include <iostream>
using namespace std;
class Point
{
public:
Point(){}
~Point()
{
cout << "executing Point destructor" << endl;
}
};
class Circle:public Point
{
public:
Circle(){}
~Circle()
{
cout << "executing Circle destructor" << endl;
}
};
int main()
{
Point *p = new Circle;
delete p;
return 0;
}
运行结果如下:
此时将基类中的析构函数声明为virtual函数,运行结果如下
如果将基类的析构函数声明为虚函数时,由该基类所派生出的所有派生类的析构函数也都自动成为虚函数,即使派生类的析构函数与基类的析构函数函数名不相同。
最好将基类的析构函数声明为虚函数。这将使所有派生类的析构函数自动成为虚函数。