内存对齐问题

内存对齐要点:
1、整体按最大基本类型对齐;
2、每个变量字段需满足其首地址能被其类型大小整除。

具体特性:
一、结构体 struct
1、时间换空间
2、向上对齐;
3、向下对齐;
4、相同类型数据不同排序,其占用空间大小不同 。

二、联合体 union
1、其所有成员引用的是内存中的相同位置,且不能同时使用多个成员;
2、联合体大小为最大基本类型大小;
3、修改一个成员会影响其余所有成员(内存覆盖技术:同一时刻只能保存一个成员的值,如果对新的成员赋值,就会把原来成员的值覆盖掉)。

union {
   char a;
   int b;
}value;
value b = 1;//由于a、b在同一块内存中,则给b赋值同时a对应所占的1字
            //节空间也存储了数据,由此可以通过b中存储的数据判断大小端问题
if(a == 1)
{
     printf("小端存储!");
}
else
{
     printf("大端存储!");
}

三、位段 (bit field)
1字节 = 8 byte
1、显示声明位段为int/unsigned int
2、没有称作为 “位段指针” 类型的变量,不可取位段地址;
3、无名位段:强制下一个变量使用新的int类型作为载体;
4、承载于1个或多个int类型之上,故其所占最大字节数为int类型的整数倍。

struct B{
    unsigned int a : 2;//4
    unsigned int word;//无名位段
    unsigned int b : 7;//4
};
sizeof(B);//8

四、枚举 enum
1、将某一变量所有可能的值一一列举出来(即此枚举变量的值仅限于枚举元素);
2、每个枚举元素都代表一个整数,按定义时的顺序默认它们的值由0开始,依次加1,直至遇到显示指定的枚举元素时改变,以后仍遵循顺序加1;
3、多用于表示随机情况。

enum Week{sun, mon, tue, wed, thu, fri, sat};
         //0    1    2    3    4    5    6
enum Week{sun, mon, tue, wed, thu, fri=6, sat};
         //0    1    2    3    4     6     7

五、自定义内存对齐方式

#pragma pack

 #pragma pack(n)//自定义内存对齐值为n
 #pragma pack()//将当前字节对齐值设为默认值(通常是8)

1、指定的对齐值 < 默认对齐大小: 以指定值为准;
2、指定的对齐值 > 默认对齐大小: 以默认值为准;
3、指定的对齐值不属于2的指数倍:以默认值为准。

六、内存对齐原因:
减少CPU的访存次数
分析:32位的PC机有64根地址总线,一次可以从内存中取出8个子节的数据。但是访问的地址必须是32/8=4的整数倍,也就是说,不能一次从地址0003向后取出8个子节的数据。所以,数据对齐后就不会因为一个数据被拆分道两个或多个4字节的单元中而造成两次访问内存。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值