《深度探索C++对象模式》——中篇

本文通过一个小例子详细解析了C++中不同类的内存布局情况,包括空类、虚继承类及多重继承类的大小计算原理,展示了内存对齐、虚基类指针等关键概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++内存布局:

先看个小例子。

class A{
};

class B:public virtual A{
};

class C:public virtual A{
};

class D:public B, public C{
};

int main()
{
    cout<<"sizeof(A)"<<sizeof(A)<<endl;
    cout<<"sizeof(B)"<<sizeof(B)<<endl;
    cout<<"sizeof(C)"<<sizeof(C)<<endl;
    cout<<"sizeof(D)"<<sizeof(D)<<endl;

    return 0;
}

输出什么,为什么?

在我的机器上(Linux ubuntu 3.2.0-23-generic #36-Ubuntu SMP Tue Apr 10 20:39:51 UTC 2012 x86_64 x86_64 x86_64 GNU/Linux)

输出:1,8,8,16

首先空类会被放置一个char占位符,也就是sizeof(A)=1了;B和C放置一个指向虚基类的指针,大小为4,再加上一个的char占位符,再内存对齐,因此是8,但是也不一定,那个char占位符有可能不被放置了,不是空类了,所以就不用内存对齐了,故也有可能是4;对于D,两份父类成员(2*8),所以是16,但是也不一定,看内存怎么排放了,有可能两个虚基类指针(2*4)+空类char占位符(1)+内存对齐(3)=12;也可能后面对齐以及占位符不要了就是8。以后面试人用,记住喽!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值