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。

 

 

 

posted on 2016-04-20 09:03  kkford  阅读(969)  评论(0编辑  收藏  举报

导航