目录
前言
修改默认对齐数
结构体传参
前言
在上一篇中,有讲解到结构体内存对齐的规则以及默认对齐数
C语言 ——— 结构体内存对齐-CSDN博客
修改默认对齐数
修改默认对齐数所需要的宏命令:#pragma
代码演示:
#pragma pack(1) // 将默认对齐数设置为8
struct s1
{
char c1;
int i;
char c2;
};
#pragma pack() // 取消设置的默认对齐数,还原成默认
将默认对齐数设置为1后,结构体成员都会从1的整数倍开始存放,那么也就是连续存放,所以最后结构体的总大小也变成了结构体的成员的总大小
代码验证:
结构体传参
结构体传参有两种方式:1.结构体直接传参;2.结构体指针传参
1. 结构体直接传参:
struct S
{
char c1;
int i;
char c2;
};
void Print(struct S s)
{
printf("%c\n%d\n%c\n", s.c1, s.i, s.c2);
}
int main()
{
struct S s1 = { 'c',1,'m' };
Print(s1);
return 0;
}
2. 结构体指针传参:
struct S
{
char c1;
int i;
char c2;
};
void Print(struct S* x)
{
printf("%c\n%d\n%c\n", x->c1, x->i, x->c2);
}
int main()
{
struct S s1 = { 's',10,'w' };
Print(&s1);
return 0;
}
代码讲解:
使用结构体直接传参时,形参部分接收时是临时拷贝了一块和结构体大小同样的空间
而结构体指针传参时,是将结构体的起始位置传递过去,形参再用同类型的结构体指针接收即可,再通过 "->" 操作符就能直接找到结构体中的成员
代码验证:
得出结论:
当结构体总大小比较大的时侯,在结构体传参时,最好是传递结构体的指针,也就是传递结构体的起始位置