1. 空类
class A
{
};
voID main()
{
printf("sizeof(A): %dn",sizeof(A));
getchar();
}
得到结果为:1。
类的实例化就是给每个实例在内存中分配一块地址。空类被实例化时,会由编译器隐含的添加一个字节。所以空类的size为1。
先了解一个概念:类的实例化,所谓类的实例化就是在内存中分配一块地址,每个实例在内存中都有独一无二的地址。同样空类也会被实例化(别拿豆包不当干粮,空类也是类啊),所以编译器会给空类隐含的添加一个字节,这样空类实例化之后就有了独一无二的地址了。所以空类的sizeof为1。
2:一般非空类大小
class CBase
{
int a;
char *p;
};
那么运行cout<<"sizeof(CBase)="< 运行结果:sizeof(CBase)=8 3.有虚函数 class CBase { public: CBase(voID); virtual ~CBase(voID); private: int a; char *p; }; 再运行:sizeof(CBase)=12 “C++ 类中有虚函数的时候有一个指向虚函数的指针(vptr),在32位系统分配指针大小为4字节”。 4.继承 有虚函数的类 基类就是上面的了不写了 class CChild : public CBase { public: CChild(voID); ~CChild(voID); private: int b; }; 运行:cout<<"sizeof(CChild)="< 输出:sizeof(CChild)=16; 可见子类的大小是本身成员变量的大小加上子类的大小。 5.静态数据成员 class A { int a; static int b; virtual voID FuncA(); }; 得到结果:8 静态数据成员被编译器放在程序的一个global data members中,它是类的一个数据成员.但是它不影响类的大小,不管这个类实际产生了多少实例,还是派生了多少新的类,静态成员数据在类中永远只有一个实体存在。 而类的非静态数据成员只有被实例化的时候,他们才存在.但是类的静态数据成员一旦被声明,无论类是否被实例化,它都已存在.可以这么说,类的静态数据成员是一种特殊的全局变量. 所以该类的size为:int a型4字节加上虚函数表指针4字节,等于8字节。 5.普通成员函数 class A { voID FuncA(); } 结果:1 类的大小与它的构造函数、析构函数和其他成员函数无关,只已它的数据成员有关。 6.普通继承 class A { int a; }; class B { int b; }; class C : public A,public B { int c; }; 结果为:sizeof(C) =12. 可见普通的继承,就是基类的大小,加上派生类自身成员的大小。 7.虚拟继承 class C : virtual public A,virtual public B { int c; }; 结果:16. 当存在虚拟继承时,派生类中会有一个指向虚基类表的指针。所以其大小应为普通继承的大小(12字节),再加上虚基类表的指针大小(4个字节),共16字节。 以上是内存溢出为你收集整理的C++类的大小——sizeof(class)全部内容,希望文章能够帮你解决C++类的大小——sizeof(class)所遇到的程序开发问题。 如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。 欢迎分享,转载请注明来源:内存溢出
评论列表(0条)