关于空结构体大小

 

在《C语言深度剖析》中说空的结构体大小为1,测试一下。代码如下:

#include <stdio.h>
 
int main()
{
    struct a
    {
    
    }st;
    printf("%d",sizeof(st));
    getchar();
}

在DEV-CPP中

编译运行输出为0.

[1OM~0UB(SCZ$R9U[)KD(]R

 

同样的代码保存为.cpp,编译运行输出为1.

SBL3P_$1{F@})]@K_RGZ{@S

由此可见关于空的结构体在C和C++中大小是不一样的。

附:C语言深度剖析里的解释如下。

 

结构体所占的内存大小是其成员所占内存之和(关于结构体的内存对齐,请参考预处
理那章)。这点很容易理解,但是下面的这种情况呢?
struct student
{
}stu;
sizeof(stu)的值是多少呢?在Visual C++ 6.0 上测试一下。
很遗憾,不是0,而是1。为什么呢?你想想,如果我们把struct student 看成一个模子
的话,你能造出一个没有任何容积的模子吗?显然不行。编译器也是如此认为。编译器认
为任何一种数据类型都有其大小,用它来定义一个变量能够分配确定大小的空间。既然如
此,编译器就理所当然的认为任何一个结构体都是有大小的,哪怕这个结构体为空。那万
一结构体真的为空,它的大小为什么值比较合适呢?假设结构体内只有一个char 型的数据
成员,那其大小为1byte(这里先不考虑内存对齐的情况).也就是说非空结构体类型数据最
少需要占一个字节的空间,而空结构体类型数据总不能比最小的非空结构体类型数据所占
的空间大吧。这就麻烦了,空结构体的大小既不能为0,也不能大于1,怎么办?定义为0.5
个byte?但是内存地址的最小单位是1 个byte,0.5 个byte 怎么处理?解决这个问题的最好
办法就是折中,编译器理所当然的认为你构造一个结构体数据类型是用来打包一些数据成
员的,而最小的数据成员需要1 个byte,编译器为每个结构体类型数据至少预留1 个byte
的空间。所以,空结构体的大小就定位1 个byte。

posted @ 2012-02-09 19:47  wangjijian  阅读(1595)  评论(0)    收藏  举报