各种同步机制的比较

类型

机制

应用场合

spinlock使用忙等方法,进程不挂起(1)用于多处理器间共享数据
(2)在可抢占的内核线程里共享数据
(3)自旋锁适合于保持时间非常短的情况,它可以在任何上下文使用,比如中断上下文
信号量阻塞式等待,进程挂起(1)适合于共享区保持时间教长的情况
(2)只能用于进程上下文
原子操作数据的原子访问(1)共享简单的数据类型:整型,比特性
(2)适合高效率的场合
rwlock特殊的自旋锁(1)允许同时读共享资源,但只能有一个写
(2)读优先于写,读写不能同时
顺序锁一种免锁机制,基于访问计数(1)允许同时读共享资源,但只能有一个写
(2)写优先于读,读写不能同时
RCU通过副本的免锁访问(1)对读占主要的场合提供高性能
(2)读访问不必获取锁,不必执行原子操作或禁止中断
关闭中断通过禁止中断的手段,排除单处理器上的并发,会导致中断延迟(1)中断与正常进程共享数据
(2)多个中断共享数据
(3)临界区一般很短

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值