iOS - 内存对齐

1. 基本的内存对齐

objectivec 复制代码
// 对象内存对齐
struct objc_object {
    // isa 指针 8 字节对齐
    isa_t isa __attribute__((aligned(8)));
};

// 定义对齐常量
#define WORD_MASK 7UL            // 字对齐掩码
#define WORD_SHIFT 3UL           // 字对齐位移
#define WORD_SIZE 8              // 64位系统下字的大小

2. 弱引用表的内存对齐

objectivec 复制代码
struct weak_entry_t {
    // 确保指针对齐
    DisguisedPtr<objc_object> referent;
    
    union {
        struct {
            // 确保引用数组对齐
            weak_referrer_t *referrers;
        };
        struct {
            // 内联数组对齐
            weak_referrer_t inline_referrers[WEAK_INLINE_COUNT];
        };
    };
};

// 弱引用表大小对齐
static size_t aligned_size() {
    return (size + WORD_MASK) & ~WORD_MASK;
}

3. 缓存对齐

objectivec 复制代码
struct cache_t {
    // bucket 数组对齐
    struct bucket_t *_buckets __attribute__((aligned(CACHE_LINE_SIZE)));
    
    // 掩码对齐优化
    mask_t _mask;  // 总是 2^n - 1
    
    // 计算对齐的大小
    static size_t bytesForCapacity(uint32_t cap) {
        return sizeof(bucket_t) * cap + sizeof(cache_t);
    }
};

4. 内存分配对齐

objectivec 复制代码
// 分配内存时的对齐处理
void *calloc(size_t count, size_t size) {
    // 计算对齐后的大小
    size_t alignedSize = (size + WORD_MASK) & ~WORD_MASK;
    
    // 分配对齐的内存
    void *result = malloc(count * alignedSize);
    if (result) {
        // 清零
        bzero(result, count * alignedSize);
    }
    return result;
}

5. 属性对齐

objectivec 复制代码
// 属性内存对齐
struct property_t {
    const char *name;
    const char *attributes;
} __attribute__((aligned(WORD_SIZE)));

// 确保属性列表对齐
struct property_list_t {
    uint32_t count;
    uint32_t size;
    property_t first;  // 这里开始的属性数组会自动对齐
};

6. 优化相关的对齐

objectivec 复制代码
// 1. CPU 缓存行对齐
#define CACHE_LINE_SIZE 64
struct cache_aligned_t {
    // 确保数据在缓存行边界上对齐
    char data[32] __attribute__((aligned(CACHE_LINE_SIZE)));
};

// 2. SIMD 指令对齐
struct simd_data {
    // 16字节对齐用于 SIMD 指令
    float values[4] __attribute__((aligned(16)));
};

7. 对齐检查和处理

objectivec 复制代码
// 检查对齐
static inline bool isAligned(const void *ptr, size_t alignment) {
    return (((uintptr_t)ptr) & (alignment - 1)) == 0;
}

// 计算对齐填充
static inline size_t alignmentPadding(size_t size, size_t alignment) {
    return (alignment - (size & (alignment - 1))) & (alignment - 1);
}

8. 内存对齐的优点

objectivec 复制代码
/*
1. 性能优化:
   - 减少内存访问次数
   - 提高缓存命中率
   - 支持原子操作

2. 硬件要求:
   - 满足处理器对齐要求
   - 支持 SIMD 指令
   - 优化内存访问

3. 内存效率:
   - 减少内存碎片
   - 优化内存布局
   - 提高访问效率
*/

总结要点:

  1. 对齐目的:
  • 提高访问效率
  • 满足硬件要求
  • 支持特殊指令
  1. 对齐实现:
  • 属性对齐
  • 结构体对齐
  • 内存分配对齐
  1. 优化考虑:
  • 缓存行对齐
  • SIMD 对齐
  • 填充优化
  1. 注意事项:
  • 内存开销
  • 平台兼容性
  • 性能影响
相关推荐
RollingPin42 分钟前
iOS八股文之 网络
网络·网络协议·ios·https·udp·tcp·ios面试
彩旗工作室12 小时前
将iOS/macOS应用上架至App Store
macos·ios·应用商店·appstore
江东小bug王15 小时前
深入解析 iOS 与 macOS 应用程序生命周期(完整指南)
macos·ios
2501_9160088919 小时前
iOS 发布全流程详解,从开发到上架的流程与跨平台使用 开心上架 发布实战
android·macos·ios·小程序·uni-app·cocoa·iphone
非专业程序员20 小时前
iOS/Swift:深入理解iOS CoreText API
ios·swift
某柚啊21 小时前
iOS移动端H5键盘弹出时页面布局异常和滚动解决方案
前端·javascript·css·ios·html5
RollingPin1 天前
iOS八股文之 RunLoop
ios·多线程·卡顿·ios面试·runloop·ios保活·ios八股文
2501_916007471 天前
iOS 混淆工具链实战,多工具组合完成 IPA 混淆与加固(iOS混淆|IPA加固|无源码混淆|App 防反编译)
android·ios·小程序·https·uni-app·iphone·webview
LinXunFeng1 天前
Flutter webview 崩溃率上升怎么办?我的分析与解决方案
flutter·ios·webview
游戏开发爱好者81 天前
FTP 抓包分析实战,命令、被动主动模式要点、FTPS 与 SFTP 区别及真机取证流程
运维·服务器·网络·ios·小程序·uni-app·iphone