为什么需要16字节对齐
需要字节对齐的原因,有以下几点:
通常内存是由一个个字节组成的,cpu在存取数据时,并不是以字节为单位存储,而是以块为单位存取,块的大小为内存存取力度。频繁存取字节未对齐的数据,会极大降低cpu的性能,所以可以通过减少存取次数来降低cpu的开销
16字节对齐,是由于在一个对象中,第一个属性isa占8字节,当然一个对象肯定还有其他属性,当无属性时,会预留8字节,即16字节对齐,如果不预留,相当于这个对象的isa和其他对象的isa紧挨着,容易造成访问混乱
16字节对齐后,可以加快CPU读取速度,同时使访问更安全,不会产生访问混乱的情况
16字节对齐算法
//16字节对齐算法
static inline size_t align16(size_t x) {
return (x + size_t(15)) & ~size_t(15);
}
原理为 首先若x=8 将原始的内存 8 与 size_t(15)相加,得到 8 + 15 = 23
将 size_t(15) 即 15进行~(取反)操作,~(取反)的规则是:1变为0,0变为1
最后将 23 与 15的取反结果 进行 &(与)操作,&(与)的规则是:都是1为1,反之为0,最后的结果为 16,即内存的大小是以16的倍数增加的
类似 (8 + 15 ) >> 4 << 4 16字节对齐
结构体和对象的内存计算实例
sizeOf -- class_getInstanceSize -- malloc_size的区别
sizeof
sizeof
是一个操作符,不是函数sizeof
计算内存大小时,传入的主要是对象或者数据类型,在编译器的编译阶段
大小就已经确定sizeof
计算出的结果,是表示占用空间的大小
class_getInstanceSize
class_getInstanceSize
runtime 提供的api,用于获取类实例对象所占内存大小
,本质也是计算该实例中所有成员变量的内存大小
malloc_size
malloc_size
获取系统实际分配的内存大小