结构体与类的字节对齐(终极方案,简单易懂)

先记住常用类型在32和64位的字节

类型 32位 64位
char 1 1
int 4 4
short 2 2
float 4 4
double 8 8
指针 4 8

只有指针在64位时不同,是8。函数指针的typedef声明不参与计算。枚举类型占内存4字节。

字节对齐

终于搞清楚结构体的字节对齐怎么计算了,看了那么多国内博客,大部分都不靠谱,要不然就是不知所云,最后看了一个印度三哥的视频讲解,没用3分钟就明白了。其实就一条规则:计算时按最大成员的大小进行逐个判断,有需要就补位

直接看几个例子:

  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
在C语言中,结构体的对齐方式是由编译器来决定的,默认情况下,编译器会对结构体进行字节对齐,以提高内存访问的效率。默认的对齐方式是根据结构体成员的大小和型决定的,例如,整型变通常会按照其字节大小进行对齐。 如果你想要实现4字节对齐(即按照4字节的倍数进行对齐),可以使用编译器提供的特殊方式来实现。在一些编译器中,可以使用`#pragma`指令或特定的编译选项来设置结构体的对齐方式为4字节。 以下是一个示例代码,演示了如何使用`#pragma`指令实现4字节对齐: ```c #pragma pack(4) struct Example { char a; int b; char c; }; #pragma pack() int main() { struct Example ex; printf("Size of struct Example: %zu\n", sizeof(ex)); return 0; } ``` 输出: ``` Size of struct Example: 12 ``` 在这个示例中,`#pragma pack(4)`指令告诉编译器以4字节对齐方式处理后续定义的结构体。然后定义了一个结构体`Example`,包含一个字符变、一个整型变和一个字符变。最后使用`#pragma pack()`指令恢复默认的对齐方式。 4字节对齐的含义是结构体的成员在内存中按照4字节的倍数进行对齐。这是为了提高内存访问的效率,因为大多数计算机体系结构对齐的数据访问速度更快。然而,这也可能会导致结构体的内存空间增大,因为可能需要填充额外的字节以满足对齐要求。 需要注意的是,对于某些特殊的硬件或特定的需求,可能需要使用特定的对齐方式。在实际开发中,应根据具体情况选择合适的对齐方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值