首页 > 代码库 > 结构体偏移量(sizeof长度)的简单研究
结构体偏移量(sizeof长度)的简单研究
总能够网上搜到这样的,关于结构体sizeof的答案,然而,经过这个简单的实验以后,发现gcc5.3编译的结果并非如此。
字节对齐的细节和具体编译器实现相关,但一般而言,满足三个准则:
1. 结构体变量的首地址能够被其最宽基本类型成员的大小所整除;
2. 结构体每个成员相对于结构体首地址的偏移量都是成员大小的整数倍,如有需要编译器会在成员之间加上填充字节;
3. 结构体的总大小为结构体最宽基本类型成员大小的整数倍,如有需要编译器会在最末一个成员之后加上填充字节。
#include <stdio.h> typedef unsigned char U8; typedef unsigned short U16; typedef unsigned int U32; typedef unsigned long long U64; typedef struct type1{ U8 size8; U32 size32; U16 size16; }type1; typedef struct type2{ U8 size8; U16 size16; U32 size32; }type2; int main(int argc, char * argv[]){ U8 size8; U16 size16; U32 size32; U64 size64; printf("U8:%d, U16:%d, U32:%d, U64:%d\n", sizeof(size8), sizeof(size16), sizeof(size32), sizeof(size64)); printf("type1:%d\ttype2:%d\n", sizeof(type1), sizeof(type2)); return 0; }
输出结果如下:
U8:1, U16:2, U32:4, U64:8 type1:12 type2:8
结构体偏移量(sizeof长度)的简单研究
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。