有虚函数的类所占内存大小

#include <iostream> 
using namespace std; 
class A   
{   
};  

class B   
{
	char ch;   
	virtual void func0()  {  } 
}; 

class C  
{
	char ch1;
	char ch2;
	virtual void func()  {  }  
	virtual void func1()  {  } 
};

class D: public A, public C
{   
	int d;   
	virtual void func()  {  } 
	virtual void func1()  {  }
};   

class E: public B, public C
{   
	int e;   
	virtual void func0()  {  } 
	virtual void func1()  {  }
};

int main(void)
{
	cout<<"A="<<sizeof(A)<<endl;    //result=1
	cout<<"B="<<sizeof(B)<<endl;    //result=8    
	cout<<"C="<<sizeof(C)<<endl;    //result=8
	cout<<"D="<<sizeof(D)<<endl;    //result=12
	cout<<"E="<<sizeof(E)<<endl;    //result=20
	getchar();
	return 0;
}

结果:

DEV C++:

VC60:


#include <iostream> 
using namespace std; 
class CommonBase
{
	int co;
};

class Base1: virtual public CommonBase
{
public:
	virtual void print1() {  }
	virtual void print2() {  }
private:
	int b1;
};

class Base2: virtual public CommonBase
{
public:
	virtual void dump1() {  }
	virtual void dump2() {  }
private:
	int b2;
};

class Derived: public Base1, public Base2//有两个带有虚函数的基类,虚指针所占大小为4*2(是一个vptr还是2个vptr呢????) 
{
public:
	void print2() {  }
	void dump2() {  }
private:
	int d;
};
int main()
{
    cout<<sizeof(Base1)<<endl;//12
    cout<<sizeof(Base2)<<endl;//12
    cout<<sizeof(Derived)<<endl;//24 如果Base1和Base2不是虚继承,则Common Base会补被当做两份不同的拷贝。从而sizeof(Derived)变成28. 
    getchar();
    return 0;
}

结果:

devc++:

VC60:


#include <iostream> 
using namespace std; 
class A
{
public:
	virtual void aa() {  }
	virtual void aa2() {  }
private:
	char ch[3];
};

class B: virtual public A
{
public:
	virtual void bb() {  }
	virtual void bb2() {  }
};

int main(void)
{
	cout<<"A's size is "<<sizeof(A)<<endl;//8
	cout<<"B's size is "<<sizeof(B)<<endl;//12
	getchar();
	return 0;
}


VC60:


参考:

C++中虚函数工作原理和(虚)继承类的内存占用大小计算

C++ 虚函数表解析

深入理解C++的动态绑定和静态绑定

C++对象大小讨论

C++对象大小讨论

对比补充例子:

#include<iostream>
using namespace std;
class B
{
      public:
             virtual void fm()
             {}
};
class D:public B
{
      public:
             virtual void fm()
             {}
};
int main()
{
    cout<<sizeof(B)<<endl;
    cout<<sizeof(D)<<endl;
    getchar();
}
DevC++下:

VC60下:


#include<iostream>
using namespace std;
class B
{
      public:
             virtual void fm()
             {}
};
class D:public B
{
      public:
             virtual void ft()
             {}
};
int main()
{
    cout<<sizeof(B)<<endl;
    cout<<sizeof(D)<<endl;
    getchar();
}

DEVC++:

VC60:

#include<iostream>
using namespace std;
class B
{
      public:
             virtual void fm()
             {}
};
class D:virtual public B
{
      public:
             virtual void fm()
             {}
};
int main()
{
    cout<<sizeof(B)<<endl;
    cout<<sizeof(D)<<endl;
    getchar();
}
DEVC++:

VC60:

#include<iostream>
using namespace std;
class B
{
      public:
             virtual void fm()
             {}
};
class D:virtual public B
{
      public:
             virtual void ft()
             {}
};
int main()
{
    cout<<sizeof(B)<<endl;
    cout<<sizeof(D)<<endl;
    getchar();
}
DEVC++:

VC60:






  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
多态对象的大小包含两部分内容:非静态数据成员和虚函数指针。其中,虚函数指针是一个指针用4个字节或8个字节(根据编译器和操作系统不同而异),用于指向虚函数表。 虚函数表的作用是存储虚函数的地址,以便在运行时动态绑定。虚函数表中存储的是虚函数的地址,而不是函数本身的代码,因此虚函数表的大小取决于虚函数的数目和编译器的实现方式。 下面是一个简单的模拟实现: ```c++ class A { public: virtual void func1() {} virtual void func2() {} private: int m_data; }; class B : public A { public: virtual void func1() {} private: char m_data; }; int main() { A* pa = new B(); delete pa; return 0; } ``` 在上面的代码中,A和B都是多态,因为它们都含有虚函数A中包含一个虚函数指针和一个int型的数据成员,因此sizeof(A)的结果可能是8或12,具体取决于编译器和操作系统。B继承自A,并覆盖了A中的一个虚函数,同时增加了一个char型的数据成员,因此sizeof(B)的结果可能是12或16。 在main函数中,通过new运算符创建了一个B型的对象,并将其指针赋值给了一个A型的指针。在delete pa语句中,会自动调用B的析构函数,并释放内存。在释放内存之前,会先调用A的析构函数,然后再调用B的析构函数,最后才释放内存。这是因为虚函数指针指向的是A的虚函数表,因此需要先调用A的析构函数,然后再调用B的析构函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值