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;
}

运行结果如下:

request中动态关联 动态关联关系_析构函数

此时将基类中的析构函数声明为virtual函数,运行结果如下

request中动态关联 动态关联关系_虚函数_02

如果将基类的析构函数声明为虚函数时,由该基类所派生出的所有派生类的析构函数也都自动成为虚函数,即使派生类的析构函数与基类的析构函数函数名不相同。

最好将基类的析构函数声明为虚函数。这将使所有派生类的析构函数自动成为虚函数。