要点:不要在构造/析构函数中调用虚函数。
原因是:
1) 子类构造函数首先调用基类构造函数,故在运行基类构造函数时,子类成员变量尚未初始化
2) 更重要的是,在调用基类构造函数时,对象的类型是基类类型。不但虚函数认为(resolve to)基类函数,运行时类型(Runtime Type Information)也认为是基类。
析构函数也是同样的原因。
如果构造函数又调用了其他成员函数,那判断构造函数是否调用了虚函数还不是显而易见的。故需要保证构造/析构函数没有调用虚函数,他们调用到的成员函数也没有。
一种解决方案是:将虚函数改为非虚函数,将与子类相关信息通过子类构造函数传递进去。
最后Mayers指出一个实现细节:在子类中使用一个辅助的私有静态函数,将处理后信息作为基类构造函数的参数。其中,使用静态函数的用意是,防止在函数中访问子类的尚未初始化的成员变量。