内存对齐以前接触过,知道有这么回事,昨天面试,面试官问了一个结构体内存分配相关的问题:
struct _A{
int a;
int b;
char c;
}A;
sizeof(A)=?(32位机器)
我一想这要涉及到内存对齐啊,sizeof(A)=12 啊,
没想到接下来面试官的一个问题就是:那如果我想节省内存,不让他内存对齐,就分配9个字节,怎么办?
当时就蒙了,一直没想过这个问题,回来后搜索了一下,果然有关闭内存对齐,整理了一下。
首先为什么需要内存对齐?
内存对齐(memory alignment).为了提高程序的性能,数据结构(尤其是栈)应该尽可能地在自然边界上对齐。原因在于,为了访问未对齐的内存,处理器需要作两次内存访问;然而,对齐的内存访问仅需要一次访问。也就是说“内存对齐”应该是编译器的管辖范围,非常依赖平台。
那么如何关闭内存对齐呢?
有两种方式:添加预处理指令 #pragma pack(1) 或者 __attribute__ ((packed))
1 添加预处理指令 #pragma pack(1)
#paragma pack(1)预处理指令的作用是结构体在分配内存时俺一个字节对齐。
#include<stdio.h>
#paragma pack(1)
struct _A{
int a;
int b;
char c;
}A;
void main()
{
printf("%d\n",sizeof(A));
}
输出结果 就是9
这里说明一下,如果用了#paragma pack(1)预处理指令,则整个文件中都会关闭内存对齐,如果只想对其中某个或某几个结构其关闭呢,这是就要用到第二种方法了。
2 利用__attribute__ ((packed))指令
#include<stdio.h>
//#paragma pack(1)
struct _A{
int a;
int b;
char c;
}__attribute__ ((packed))A;
struct _B{
int a;
int b;
char c;
}B;
void main()
{
printf("%d\n",sizeof(A));
printf("%d\n",sizeof(B));
}
输出结果就是
9
12
就先总结到这儿吧。
想了解更多的__attribute__机制介绍 ,可以看一下
这篇博文 : 点击打开链接