iOS - 内存对齐

news/2025/1/16 9:42:19/

1. 基本的内存对齐

// 对象内存对齐
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. 弱引用表的内存对齐

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. 缓存对齐

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. 内存分配对齐

// 分配内存时的对齐处理
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. 属性对齐

// 属性内存对齐
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. 优化相关的对齐

// 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. 对齐检查和处理

// 检查对齐
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. 内存对齐的优点

/*
1. 性能优化:- 减少内存访问次数- 提高缓存命中率- 支持原子操作2. 硬件要求:- 满足处理器对齐要求- 支持 SIMD 指令- 优化内存访问3. 内存效率:- 减少内存碎片- 优化内存布局- 提高访问效率
*/

总结要点:

1. 对齐目的:

  • 提高访问效率
  • 满足硬件要求
  • 支持特殊指令

2. 对齐实现:

  • 属性对齐
  • 结构体对齐
  • 内存分配对齐

3. 优化考虑:

  • 缓存行对齐
  • SIMD 对齐
  • 填充优化

4. 注意事项:

  • 内存开销
  • 平台兼容性
  • 性能影响

http://www.ppmy.cn/news/1563560.html

相关文章

机器学习在服务监控中的创新应用:提升运维效率与可靠性

《机器学习在服务监控中的创新应用:提升运维效率与可靠性》 一、引言 在当今复杂的信息技术环境中,服务监控对于确保系统的稳定运行至关重要。传统的服务监控方法往往依赖于预定义的阈值和规则,但在面对复杂多变的服务行为时,这些方法可能会显得力不从心。机器学习的出现…

HarmonyOS NEXT应用开发边学边玩系列:从零实现一影视APP (四、最近上映电影滚动展示及加载更多的实现)

在HarmonyOS NEXT开发环境中&#xff0c;可以使用多种组件和库来构建丰富且交互友好的应用。本文将展示如何使用HarmonyOS NEXT框架和nutpi/axios库&#xff0c;从零开始实现一个简单的影视APP的首页&#xff0c;主要关注最近上映电影的滚动展示及加载更多功能的实现。 开源项目…

CSS的小知识

一、子选择器 (>) 让 CSS 样式只作用于子级和孙级元素&#xff0c;而不影响其他元素 有>是只对其子级有效&#xff0c;子选择器只会影响直接的子级元素&#xff0c;而不会影响更深层次的孙级元素 无>时是对子级、孙级、曾孙级等所有后代都有效

我在2025年自学网络安全(黑客)

当我们谈论网络安全时&#xff0c;我们正在讨论的是保护我们的在线空间&#xff0c;这是我们所有人的共享责任。网络安全涉及保护我们的信息&#xff0c;防止被未经授权的人访问、披露、破坏或修改。 一、网络安全的基本概念 网络安全是一种保护&#xff1a;它涉及保护我们的…

栈算法篇——LIFO后进先出,数据与思想的层叠乐章(上)

文章目录 前言第一章&#xff1a;栈的基础知识回顾1.1 栈的结构与实现1.2 栈的应用第二章&#xff1a;删除字符串中的所有相邻重复项2.1 题目链接&#xff1a;https://leetcode.cn/problems/remove-all-adjacent-duplicates-in-string/description/2.2 题目分析&#xff1a;2.3…

刷题记录 回溯算法-13:90. 子集 II

题目&#xff1a;90. 子集 II 给你一个整数数组 nums &#xff0c;其中可能包含重复元素&#xff0c;请你返回该数组所有可能的 子集 &#xff08;幂集&#xff09;。 解集 不能 包含重复的子集。返回的解集中&#xff0c;子集可以按 任意顺序 排列。 示例 1&#xff1a; …

钉钉消息推送()

记录一下java实现消息推送 1. 首先添加依赖 <dependencies><dependency><groupId>com.aliyun</groupId><artifactId>alibaba-dingtalk-service-sdk</artifactId><version>2.0.0</version></dependency><dependency&…

Python Chardet 库详解:字符编码检测的利器

Python Chardet 库详解&#xff1a;字符编码检测的利器 在处理文本数据时&#xff0c;字符编码问题是一个常见的挑战。如果编码不正确&#xff0c;可能会导致乱码问题。而 Chardet 是 Python 中非常实用的一个库&#xff0c;可以帮助我们快速检测文件或字符串的编码格式。 1.…