派生类构造函数中调用基类虚函数,能够发生多态?-(否)

#include
using namespace std;


class A{
public:
    A(int a) :a(a)
    { 
        cout << "constructor A :" << a << endl;
        test1();
        test2();
    }


    void test1(){ cout << "Class A :" << a << endl; }
    virtual void test2(){ cout << "Class A Virtual:" << a << endl; }


protected:
    int a;
};


class B :public A{
public:
    B(int b) :A(b)
    { 
        cout << "constructor B :" << a << endl;
        test1();
        test2();
    }


    void test1(){ cout << "Class B :" << a << endl; }
    void test2(){ cout << "Class B Virtual:" << a << endl; }
};


int main()
{
    cout << "==========0=========" << endl;
    A a(10);
    cout << "==========1=========" << endl;
    B b(20);
    A *ptr = NULL;


    cout << "==========2=========" << endl;
    ptr = &a;
    ptr->test1();
    ptr->test2();


    cout << "==========3=========" << endl;
    ptr = &b;
    ptr->test1();
    ptr->test2();


    return 0;
}

执行结果为:

派生类构造函数中调用基类虚函数,能够发生多态?-(否)_第1张图片

    从结果中可以看出,派生类B在构建时,基类A的构造函数中的虚函数调用的是基类的函数test2(),而没有调用派生类B的test2()函数;

    为什么会出现这个现象呢?因为这个跟vptr指针有关系,因为对象的vptr指针是在实例创建完成后再赋值具体的实例虚函数表,在派生类B构建过程中,首先调用的是A类的构造函数,而此时B类还未构建完成,此时调用的虚函数test2()还是A类的虚函数。

    因此在派生类构造函数中调用的虚函数不表现出多态性。



你可能感兴趣的:(C/C++,构造函数,多态,VPTR指针)