ios-底层原理02内存对齐

在实验过程中发现,结构体中成员的顺序不一样时,结构体所占内存大小不同,进行如下探究:

struct personOne {
    int a;      //4个字节 [0 3]
    bool b;     //1个字节 [4]
    double c;   //8个字节 取8的倍数存 [8 15]
    char d;     //1个字节 [16]
                //最大字节整数倍 进行补齐 24个字节
};
struct personTwo {
    int a;      //4个字节 [0 3]
    bool b;     //1个字节 [4]
    char d;     //1个字节 [5]
    double c;   //8个字节 取8的倍数存 [8 15]
                //最大字节整数倍 进行补齐 16个字节
};

struct personT {
    int a;      //4个字节 [0 3]
    bool b;     //1个字节 [4]
    char d;     //1个字节 [5]
    double c;   //8个字节 取8的倍数存 [8 15]
    personTwo two; //16个字节  [16 31]
                    //最大字节整数倍 进行补齐 32个字节
};
   NSLog(@"personOne内存大小==%lu",sizeof(personOne));
   NSLog(@"personTwo内存大小==%lu",sizeof(personTwo));
   NSLog(@"personT内存大小==%lu",sizeof(personT));      

输出结果如下
在这里插入图片描述

字节对齐原理:
  1. 数据成员对齐规则:结构体(struct)或联合(union)的数据成员,第一个数据成员放在offset0的地方,以后每个数据成员存储的起始位置要从该成员大小或者成员的子成员大小(只要该成员有子成员,比如说数组、结构体等)的整数倍开始(int4字节,则要从4整数倍地址开始存储)
  2. 结构体作为成员:如果一个结构里有某些结构体成员,则结构体要从其内部最大元素大小的整数倍地址开始存储(例:struct a里存有struct bb里有charintdouble等元素,那b应该从8的整数倍开始存储)
  3. 结构体的总大小,也就是sizeof的结果,必须是其内部最大成员的整数倍,不足的要补齐。
字节对齐的原因:

内存是以字节为基本单位,cpu在存取数据时,是以为单位存取,并不是以字节为单位存取,频繁存取未对齐的数据,会极大降低cpu的性能。字节对齐后,会减少cpu的存取次数,这种以空间换时间的做法目的是降低cpu的开销cpu存取是以为单位,存取未对齐的数据可能开始在上一个内存块,结束在另一个内存块,这样中间可能要经过复杂运算合并再一起,降低了效率,字节对齐后,提高了cpu的访问率。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值