#include<iostream>
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;
}
执行结果为:
从结果中可以看出,派生类B在构建时,基类A的构造函数中的虚函数调用的是基类的函数test2(),而没有调用派生类B的test2()函数;
为什么会出现这个现象呢?因为这个跟vptr指针有关系,因为对象的vptr指针是在实例创建完成后再赋值具体的实例虚函数表,在派生类B构建过程中,首先调用的是A类的构造函数,而此时B类还未构建完成,此时调用的虚函数test2()还是A类的虚函数。
因此在派生类构造函数中调用的虚函数不表现出多态性。