为什么结构体打印的是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;
} 结构体的大小是由其成员的大小和对齐方式决定的。在大多数情况下,编译器会对结构体进行内存对齐操作,以提高读写效率。
在你的代码中,`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:28 编辑
12 + 4 + 4 + 4 x 4 = 36
这难道不是一道简单的算术题吗?
由于结构体 student 中的每一个成员所占用的内存数量都已经是 4 的倍数了,所以,就不存在内存对齐的问题了,如果为其增加定义一个 char 型的成员,你就会发现,这个新成员占用的是 4 (而不是 1 )个字节的内存空间,从而就产生了内存对齐的效应。
页:
[1]