C++构造函数与虚表覆盖
在涉及到虚函数的情况下,C++构造函数的构造顺序为:先调用构造函数,虚表指针初始化,用户代码;如涉及到多重继承情况,初始化顺序为基类、子类(从左至右),假设一个类的继承情况如下图,其初始化顺序为:Point,Point3d,Vertex,Vertex3d,PVertex,而这样的调用顺序说明在构造函数中调用虚函数是安全的,即时在初始化列表中基类构造函数在用户函数后面,g++编译器亦会自动调整。
我们假设上述类的虚函数中设计到虚函数(析构函数未计算)如上图所示,虚函数中出现了重载,子类中选择性重载虚函数,虚函数与重载就会出现:重载优先级高于虚函数的情况。PVertex类中只实现z(int)函数的情况下:
PVertex vertex(3); Vertex3d *p = &vertex; Vertex *q = &vertex; PVertex *p1 = &vertex; cout << "call z function:" << endl; p1->z(0.1f);
输出结果如下:
Point::Point() Point3d::Point3d() Vertex::Vertex() Vertex3d::z(int)3 Vertex3d::Vertex3d(int) PVertex::PVertex() call z function: PVertex::z(int):0 ~PVertex::PVertex() ~Vertex3d::Vertex3d() ~Vertex::Vertex() ~Point3d::Point3d() ~Point::Point()
此时PVertex并不调用V::z(float),PVertex::z(int)覆盖了函数Vertex::z(float),覆盖解决方法还是在PVertex中加入声明: using Vertex3d::z。