目录
一:字节对齐概述
二:字节对齐原则
三:设置编译器对齐系数n的两种方法
四:代码示例
正文
一:字节对齐概述
cpu根据自身处理器的字长和数据总线宽度确定一条指令寻址的位数,比如16位处理器每次访问16bit的数据,为了提高处理器效率,编译器会对不同数据类型的变量进行内存对齐。
二:字节对齐原则
字节对齐三原则:(以结构体数据类型为例)
1:确定有效对齐位数;
假设设置编译器的对齐位数为n,最终有效对齐位数为N,N=Min(n,结构体成员所占字节数),n和N都是以字节为单位;
2:结构体成员自身对齐;
确定有效对齐位数后,需满足结构体成员起始地址%N=0;
3:结构体整体对齐
结构体成员自身对齐后,结构体整体大小是有效对齐位N的整数倍;
三:设置编译器对齐系数n的两种方法
1:可以通过预编译指令#pragma pack(n),n=1,2,4,8,16来指定编译器的对齐系数n;
2:_attribute_机制,此机制为GUN C的扩展,适用GCC编译器, _attribute_ ((aligned (n)))可以指定编译器的对齐系数,_attribute_((packed))指定变量或者结构体或者共用体采用最小对齐模式,即一字节对齐,位域是位对齐;
四:代码示例
本文详细介绍了CPU字节对齐的概念及其重要性,并解释了编译器如何实现不同数据类型的内存对齐。文中还提供了设置编译器对齐系数的具体方法及代码示例。
1289

被折叠的 条评论
为什么被折叠?



