struct对齐问题

ChinaUnix最近有个贴子讨论热烈,在这里记录一下我的理解,struct的对齐是遵照下列二个条件中最小的一个进行的:
1.#pragma pack(N)中N指定的值
2.struct中最大的成员(请注意不是指sizeof值最大的那个,而应当是__alignof__值最大的那个)

对于double等几个类型,它的alignof值是可通过编译开关-mno-align-double和-malign-double来控制的,其中-mno-align-double表示double的alignof值为字长,而-mno-align-double表示alignof值为两个字长。但是alignof的值不会超过sizeof值,且其总是2的幂数,所以在64位上double的alignof和sizeof总是相同的。

示例:
在i386和x86_64上(其它不清楚):
#pragma pack(M)
struct X
{
    int64_t a;
    int32_t c;
    int64_t b;
};
#pragma pack()

字节对齐不一定是按M对齐,而是按M、结构体的字节最大成员和alignof(long)中最小的一个对齐,而在powerpc(AIX)上,则按M和结构体的字节最大成员中的最小一个对齐。

C++11已经支持alignof操作符,之前的版本可以使用GCC提供的宏:__alignof__,可以在代码中直接使用。

扩展阅读:http://blog.chinaunix.net/uid-20682147-id-3761787.html(Linux内核list/hlist解读)

转载于:https://www.cnblogs.com/aquester/archive/2012/07/24/9891819.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
内存对齐是指为了提高处理器读写数据的效率,将结构体或类的成员按照一定规则进行排列,使得每个成员的起始地址的偏移量都是该成员类型所占字节的整数倍。这样可以确保处理器可以一次读取或写入多个字节数据,提高访问速度。 在设计结构体时,我们既要满足对齐要求,又要节省空间,可以采取以下几种方式: 1. 调整成员顺序:将占用空间小的成员尽量集中在一起,这样可以减少空隙的产生。例如,可以将char类型的成员放在一起,再将int类型的成员放在一起,这样可以减少空隙的大小。 2. 使用编译器的对齐指令:可以使用编译器提供的对齐指令,如#pragma pack(n),将变量以n字节方式对齐。通过设置合适的n值,可以实现更灵活的对齐方式。需要注意的是,结构体的总大小仍然要为占用空间最大的成员变量的倍数。 3. 调整编译器的默认对齐数:有些编译器允许修改默认的对齐数,可以通过修改编译器的默认对齐数来影响结构体的对齐方式。 总之,通过调整成员顺序,使用编译器的对齐指令或修改编译器的默认对齐数,我们可以在满足对齐要求的前提下尽量节省空间。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [struct结构体的内存对齐](https://blog.csdn.net/chirrupy_hamal/article/details/102634695)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [关于struct的内存对齐问题](https://blog.csdn.net/element137/article/details/69075284)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值