构造派生类对象时首先运行基类构造函数初始化对象的基类部分。在执行基类构造函数时,
对象的派生类部分是未初始化的。实际上,此时对象还不是一个派生类对象。
撤销派生类对象时,首先撤销它的派生类部分,然后按照与构造顺序的逆序撤销它的基类部分。
在这两种情况下,运行构造函数或析构函数的时候,对象都不是完整的。为了适用这种不完整,
编译器将对象的类型视为在构造和析构期间发生了变化。在基类构造函数或析构函数中,将派生类对象
当做基类类型对象对待。
构造或析构期间的对象类型对虚函数的绑定有影响。
ps:如果在构造函数或析构函数中调用虚函数,则运行的是为构造函数或析构函数自身类型定义的版本。
无论由构造函数或析构函数直接调用希函数,或者从构造函数或析构函数所调用的函数简介调用虚函数,
都应用这种绑定。
要理解这种行为,烤炉如果从基类构造函数(或析构函数)调用虚函数的派生类版本会怎么样。虚函数的派生类版本
很可能会访问派生类对象的成员。毕竟,如果派生类版本不需要使用派生类对象的成员,派生类多半能够使用基类的定义。
但是,对象的派生部分的成员不会在基类构造函数运行期间初始化,实际上,如果允许这样的访问,程序很可能会崩溃
摘在《C++primer》第三版 构造函数与析构函数中的虚函数 497页