如下,我们有一个FHello
通过sizeof的方法获取并打印
class FHello {
};
int main(){
FHello o ;
int len = sizeof(o)
cout<<"大小"<
输出为1
这一个字节只是一个占位字节,只是为了占位;
那么如果有一个类继承自它呢?
class FHello {
};
class FHello1:public FHello{
};
int main(){
FHello1 o ;
int len = sizeof(o)
cout<<"大小"<
输出还是一个字节
为什么?
因为它们都什么都没有,编辑器为了区分,便会自动给它们一个字节,这个字节是为了占位的
如下,我们给FHello添加一个虚函数,它输出将会是4,添加两个虚函数,输出依然是4,为什么?这便涉及到虚函数原理
#include
using namespace std;
class FHello {
public:
virtual void wocao(){}
virtual void wocao1() {}
};
class FHello1 :public FHello {
};
int main() {
FHello1 o;
int len = sizeof(o);
cout << "大小" << len<< "字节" << endl;
return 0;
}
这四个字节是什么,是我们的虚函数指针
虚函数一旦被调用,它便会自动创建一个对应类的虚函数指针(vrptr)以及一个Vtable表
这个虚函数指针会指向Vtable表
而表中会储存虚函数,如果它储存了一个纯虚函数那么它表中也会储存这个等于0的函数
当虚函数指针指向一个等于0的纯虚函数的时候,会发现执行不了
便会提示用户,需要实现,然后我们通过继承来实现
它便会将重写的虚函数和vatable中的纯虚函数从Vtable中直接替换掉
替换以后我们便无法执行原来的=0的函数,而我们执行的是Vtable中的函数
这样我们便实现了只需要调用基类就可以调用子类的方法
而实际上我们调用的是表中的内容



