vptr指针分部初始化
vptr指针分部初始化)
vptr指针在初始化时会分部初始化
即父类的指针指向子类时,对子类进行构造时,会先构造父类,vptr指针会先指向父类虚函数表,再指向子类虚函数表
测试代码
Child类继承了Parent类,我们在main类中定义了一个Child类的对象,构造Child是会先调用Parent的构造函数,我们在Parent类和Child都写了虚函数print()函数,然后在Parent类的构造函数中,调用了print()函数,通过看结果中是调用了父类的print()函数还是子类的print()函数,如果调用了父类的print(),就可以证明子类的vptr指针在构造父类时改变了指向,先指向了Parent类的虚函数表,构造结束过后再恢复指向Child类的虚函数表
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;
class Parent {
public:
Parent(int a) {
cout << "Parent()..." << endl;
this->a = a;
print();
}
virtual void print() {
cout << "皮卡丘站起来了" << endl;
}
~Parent() {
cout << "~Parent()..." << endl;
}
private:
int a;
};
class Child :public Parent
{
public:
Child(int b):Parent(30) {
this->b = b;
cout << "Child()..." << endl;
}
~Child() {
cout << "~Child()..." << endl;
}
virtual void print() {
cout << "pikapika" << endl;
}
private:
int b;
};
int main() {
Child* bp = new Child(20);
delete bp;
system("pause");
return 0;
}
结果打印的是“皮卡丘站起来了”(父类的虚print()函数打印的),从这里,我们就可以得出vptr指针一开始会改变指向而指向父类的结果啦,即vptr指针会分部初始化。