在类成员函数中调用虚函数是间接调用,调用是通过this指针的。构造函数和析构函数内部都不存在多态性,构造函数本身不允许被定义成虚函数(从逻辑上讲,一个对象在构造的时候已经确定是什么类了,不存在多态也没有意义),构造函数里的虚函数编译器会硬编码地址,如果构造函数调用了一个含有虚函数调用的成员函数呢?我们知道虚函数表指针是在构造代码执行前进行初始化,指向本类的虚函数表。所以即使成员函数内部间接调用虚函数,虚表的关系最终调用的还是本类的虚函数。因此从逻辑上看,构造中没有多态调用(所有的虚函数都是本类的虚函数)。析构的做法同构造一样,硬编码加初始化虚函数表指针,从逻辑上消除多态调用。
抽象类指类的定义中至少有一个纯虚函数(定义时赋值0,没有具体实现),抽象类不能被实例化,它通常表示一个接口规范,每个纯虚函数对应每个功能的位置,对接口而言结构不应该发生改变(至少要兼容),所以一般不定义数据成员。