C++中结构体占字节数(sizeof)

来源:互联网 发布:公安部软件检测中心 编辑:程序博客网 时间:2024/03/29 01:02

C++中结构体占字节数(sizeof)

首先看一段代码

  struct X{    char a;    int b;    double c;    }SRT;int main(){    cout << sizeof(SRT) << endl;    cout << sizeof(SRT.a) << endl;    cout << sizeof(SRT.b) << endl;    cout << sizeof(SRT.c) << endl;    return 1;  }

输出为 sizeof(SRT)=16 sizeof(SRT.a)=1 sizeof(SRT.b)=4 sizeof(SRT.c)=8
出现这种情况的原因是内存字节对齐导致

当然 这里记住两个原则就可以将这个问题搞清楚

第一 结构体中的元素是按照顺序一个个放入内存,而且每个元素放入的首地址(相对地址)一定是自己本身长度的整数倍 如上代码中a占了0~3 b占4~7 c占8~15 0 4 8 分别是 char int double 的整数倍位置

我们再看一段代码

 struct X{    char a;    double b;    int c;    }SRT;int main(){    cout << sizeof(SRT) << endl;    cout << sizeof(SRT.a) << endl;    cout << sizeof(SRT.b) << endl;    cout << sizeof(SRT.c) << endl;    return 1;  }

将第一处的代码的double 与int 换了一个位置后 得到sizeof(SRT)=24 char 放在了0~7 double在8~15
int在16~19 所以这里涉及到第二个原则

第二 占空间为最大数据占空间的整数倍 所以在内存20~23为对齐补全的。

最后顺便说一下联合体 union
  由于联合体中的所有成员是共享一段内存的,因此每个成员的存放首地址相对于于联合体变量的基地址的偏移量为0,即所有成员的首地址都是一样的。为了使得所有成员能够共享一段内存,因此该空间必须足够容纳这些成员中最宽的成员。
 union U {     char s[9];     int n;     double d; };int main(){     union U u1;     cout<< sizeof(u1)<<endl;}

sizeof(u1)=16 double的整数倍 (为什么不是8 因为char[9]占9字节 最大)
如果有错误 欢迎指正 比心 (ylucas923@gmail.com)

原创粉丝点击