hanghanga 发表于 2023-12-21 22:31:32

为什么结构体打印的是36呢?

如题,内存是怎么对齐的?
#include <stdio.h>

struct Student
{
    char name;
    int age;
    int sex;
    float score;
};
   
struct Student student;

int main(void)
{
    int a = sizeof(student);
    printf("%d", a);

    return 0;
}

FishC 发表于 2023-12-21 22:31:46

结构体的大小是由其成员的大小和对齐方式决定的。在大多数情况下,编译器会对结构体进行内存对齐操作,以提高读写效率。

在你的代码中,`struct Student`的成员依次为`char name`、`int age`、`int sex`、`float score`。其中,`char`类型占1个字节,`int`类型占4个字节,`float`类型占4个字节。

根据对齐方式,默认情况下,成员的大小会被调整为它所属的结构体的倍数,以保证每个成员都起始于相应的对齐地址上。在32位的机器上,对齐单位通常为4个字节。

因此,在你的代码中,`char name`占1个字节,由于`int age`的大小为4个字节,它需要对齐到4个字节的边界,所以在`char name`后面会有3个字节的空隙。`int sex`和`float score`也分别占用了4个字节。

所以,`sizeof(student)`的结果为36,因为1+3+4+4+4+4+4+4=36。

如果你想要减小结构体的大小,可以尝试调整成员的顺序,将占用空间较小的成员放在前面,以减少空隙的大小。或者通过编译器提供的指令来调整对齐方式。不过这些方法都可能会导致读写效率的下降,所以需要根据实际情况权衡。

希望以上解答能解决你的疑问!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

jackz007 发表于 2023-12-21 23:06:13

本帖最后由 jackz007 于 2023-12-21 23:28 编辑

12 + 4 + 4 + 4 x 4 = 36
      这难道不是一道简单的算术题吗?
      由于结构体 student 中的每一个成员所占用的内存数量都已经是 4 的倍数了,所以,就不存在内存对齐的问题了,如果为其增加定义一个 char 型的成员,你就会发现,这个新成员占用的是 4 (而不是 1 )个字节的内存空间,从而就产生了内存对齐的效应。
页: [1]
查看完整版本: 为什么结构体打印的是36呢?