如何理解虚表及其计算含虚函数的类的大小
在什么情况下系统会自动生成缺省(默认)的构造函数?
网站建设、网站制作的关注点不是能为您做些什么网站,而是怎么做网站,有没有做好网站,给成都创新互联公司一个展示的机会来证明自己,这并不会花费您太多时间,或许会给您带来新的灵感和惊喜。面向用户友好,注重用户体验,一切以用户为中心。
1、在类里面有一个类类型的对象,这个类有自己的缺省构造函数(有缺省的参数,参数有缺省值)。
class B
{
B(int data)
{ }
};不能合成
class B
{
B(int data=0)
{ }
};会合成
class B
{
public:
B(int data=0)
{ }
};
class C:public B
{
public:
C()
:B(0)
{ }
B b; //编译器会自动合成
};
2、类是虚拟继承
class B
{
public:
B()
{}
};
class D:virtual public B
{
public:
D()
{ }
B b;
};
3、基类有缺省构造函数,子类没有显示定义自己的构造函数
class B
{
public:
B(int data=0)
{}
};
class D: public B
{
public:
};
4、有虚函数的类,系统自动生成缺省的构造函数来初始化虚指针
class B
{
public:
virtual void fun()
{
cout << "fun" << endl;
}
};
前面是一些构造函数方面的总结,菜鸟一个写的太烂,进来的先凑合着看,会不定时补充,有错误的地方还请多多指点
****************************************************************************************
虚函数:
class Base
{
public:
virtual void FunTest()
{
cout << "Base::FunTest()" << endl;
}
virtual void FunTest1()
{
cout << "Base::FunTest1()" << endl;
}
virtual void FunTest2()
{
cout << "Base::FunTest2()" << endl;
}
virtual void FunTest3()
{
cout << "Base::FunTest3()" << endl;
}
virtual void FunTest4()
{
cout << "Base::FunTest4()" << endl;
}
};
int main()
{
Base b;
system("pause");
return 0;
}
Base b;
009253E8 lea ecx,[b]
009253EB call Base::Base (0921226h)
有call命令说明编译器有合成缺省构造函数
取b的地址,b指向的那块空间里存放着另一个地址,该地址指向的空间存放着虚表地址
虚指针指向虚表
虚表的顺序和函数的声明顺序是一样的
虚函数的大小:
***************************计算大小*********************************
class C
{
public:
char a; //1
static char b; //静态成员在静态区域,不在栈区,所以不算
void *p; //指针占4个字节
static int *c; //静态成员在静态区域,不在栈区,所以不算
virtual void func1()
{}
virtual void func2()
{}
//虚函数属于同一类,故只需要一个这个指针指向虚函数表,
//占用4个字节,就算有N个虚函数,也是4个字节
};
int main()
{
C c;
cout << sizeof(C) << endl; //12
cout << sizeof(c.a) << endl; //1
cout << sizeof(c.b) << endl; //1 类型的大小
cout << sizeof(c.c) << endl; //4 类型的大小
cout << sizeof(c.p) << endl; //4
return 0;
}
文章标题:如何理解虚表及其计算含虚函数的类的大小
转载源于:http://pcwzsj.com/article/gcjjsj.html