当前位置: 首页 > news >正文

iOS - Objective-C 底层中的内存屏障

1. 基本实现

// objc-os.h 中的内存屏障实现
#define OSMemoryBarrier()  __sync_synchronize()// ARM 架构特殊处理
static ALWAYS_INLINE void
OSMemoryBarrierBeforeUnlock() {
#if defined(__arm__) || defined(__arm64__)OSMemoryBarrier();
#endif
}

2. 解锁前的内存屏障

// 自旋锁解锁时使用内存屏障
static ALWAYS_INLINE void
OSSpinLockUnlock(volatile OSSpinLock *lock) {// 确保之前的内存操作都完成OSMemoryBarrierBeforeUnlock();// 解锁操作OSAtomicAnd32Barrier(0, &lock->value);
}

3. 原子操作中的内存屏障

// 带内存屏障的原子操作
static ALWAYS_INLINE int32_t 
OSAtomicIncrement32Barrier(volatile int32_t *value) {// 使用带内存屏障的原子加操作return __sync_fetch_and_add(value, 1) + 1;
}static ALWAYS_INLINE int32_t 
OSAtomicDecrement32Barrier(volatile int32_t *value) {// 使用带内存屏障的原子减操作return __sync_fetch_and_sub(value, 1) - 1;
}

4. 不同架构的处理

// 针对不同架构的内存屏障实现
#if __has_feature(c_atomic)// 使用 C11 原子操作#define OSAtomicIncrement32Barrier(p) \__c11_atomic_add((_Atomic(int32_t) *)(p), 1, __ATOMIC_SEQ_CST)
#else// 使用平台特定的实现static ALWAYS_INLINE int32_t OSAtomicIncrement32Barrier(volatile int32_t *value) {return __sync_fetch_and_add(value, 1) + 1;}
#endif

5. 使用场景

5.1 引用计数操作

bool objc_object::rootTryRetain() {// 使用带内存屏障的原子操作if (OSAtomicCompareAndSwapInt32Barrier(0, 1, &refcount)) {return true;}return false;
}

5.2 属性原子访问

// 原子属性的 setter
static inline void reallySetProperty(id self, SEL _cmd, id newValue, ptrdiff_t offset, bool atomic) 
{if (atomic) {spinlock_t& slotlock = PropertyLocks[GOODHASH(offset)];slotlock.lock();// 写入值*((id *)((char *)self + offset)) = newValue;// 确保内存操作完成OSMemoryBarrier();slotlock.unlock();}
}

6. 内存序保证

// 1. Acquire 语义
#define ACQUIRE_BARRIER() \__asm__ __volatile__("dmb ish" : : : "memory")// 2. Release 语义
#define RELEASE_BARRIER() \__asm__ __volatile__("dmb ish" : : : "memory")// 3. 完全内存屏障
#define FULL_BARRIER() \__asm__ __volatile__("dmb ish" : : : "memory")

7. 性能考虑

// 1. 避免不必要的内存屏障
void performOperation() {if (!needsBarrier) {// 使用非屏障版本的操作OSAtomicIncrement32(value);} else {// 使用带屏障版本OSAtomicIncrement32Barrier(value);}
}// 2. 合并内存屏障
void batchOperations() {// 一次内存屏障保护多个操作OSMemoryBarrier();// 执行多个操作operation1();operation2();operation3();OSMemoryBarrier();
}

总结要点:

1. 内存屏障类型:

  • 完全内存屏障
  • 获取屏障(Acquire)
  • 释放屏障(Release)

2. 使用场景:

  • 锁操作
  • 原子操作
  • 属性访问
  • 引用计数

3. 架构相关:

  • ARM 特殊处理
  • x86 内存序列
  • 不同平台实现

4. 性能影响:

  • 内存屏障开销
  • 合理使用
  • 优化策略

5. 注意事项:

  • 正确使用类型
  • 避免过度使用
  • 考虑性能影响
  • 平台兼容性
http://www.lryc.cn/news/521372.html

相关文章:

  • 阿里云服务器扩容系统盘后宝塔面板不显示扩容后的大小
  • c语言——【linux】多进程编程 【进程的创建,相关shell指令,进程状态切换,回收资源,守护进程等】
  • macos 搭建 ragflow 开发环境
  • 信创改造-龙蜥操作系统搭载MySql、Tomcat等服务
  • Java 数据结构 队列之双端队列 常用方法 示例代码 及其实现
  • 【原创】大数据治理入门(2)《提升数据质量:质量评估与改进策略》入门必看 高赞实用
  • arcgis中生成格网矢量带高度
  • 使用gtsam添加OrientedPlane3Factor平面约束因子
  • 换了城市ip属地会变吗?为什么换了城市IP属地不变
  • 移远通信多模卫星通信模组BG95-S5获得Skylo网络认证,进一步拓展全球卫星物联网市场
  • IntelliJ IDEA Type Hierarchy Scope Pattern 学习指南
  • 简聊MySQL并发事务中幻读、虚读问题的解决方案
  • 【搭建JavaEE】(2)Tomcat安装配置和第一个JavaEE程序
  • 【Qt】01-了解QT
  • websocket股票行情接口
  • 朴素贝叶斯分类器
  • 智能化植物病害检测:使用深度学习与图像识别技术的应用
  • vim基本命令(vi、工作模式、普通模式、插入模式、可视模式、命令行模式、复制、粘贴、插入、删除、查找、替换)
  • Qt 自动根据编译的dll或exe 将相关dll文件复制到目标文件夹
  • 探索新能源汽车“芯”动力:AUTO TECH China 2025广州国际新能源汽车功率半导体技术展盛况空前
  • Kafka权威指南(第2版)读书笔记
  • WORD转PDF脚本文件
  • electron 打包后的 exe 文件,运行后是空白窗口
  • 数据库重连 - 方案
  • 从 PostgreSQL 中挽救损坏的表
  • 【Vue3 入门到实战】1. 创建Vue3工程
  • rtthread学习笔记系列(10/11) -- 系统定时器
  • mock服务-通过json定义接口自动实现mock服务
  • 像JSONDecodeError: Extra data: line 2 column 1 (char 134)这样的问题怎么解决
  • C#版 软件开发6大原则与23种设计模式