我有一个结构,它有三个字段,定义如下:
struct tmp {
char *ptr;
unsigned int data1;
unsigned int data2;
};在使用英特尔沙桥处理器的64位系统上与GCC一起编译后,sizeof(tmp)返回24。
据我所知,编译器向两个"unsigned int“字段都填充了4个字节。但是,如果没有填充并且结果结构的大小是16,会不会更好呢?
想象一下,如果有这样一个结构的数组,通过强制结构的大小为16,可以确保数组中没有单个结构被拆分到高速缓存线上,因为英特尔SandyBridge处理器的高速缓存线大小是64字节。因此减少了在循环通过数组时具有两次存储器访问以获取这样的结构的机会。
发布于 2012-02-13 12:15:50
我不明白您的编译器为什么要填充unsigned int成员,假设您没有unsigned int不是32位的一些奇怪的设置。在我的GCC上,我得到了sizeof(struct tmp) == 16。
如果打印出每个成员的地址,会发生什么情况?这应该可以帮助您找出填充在哪里。但在任何情况下,您都应该能够通过告诉GCC打包结构来消除填充,如下所示:
struct tmp {
char *ptr;
unsigned int data1;
unsigned int data2;
} __attribute__((packed));https://stackoverflow.com/questions/9255342
复制相似问题