linux无锁编程

本文探讨了Linux无锁编程中的两种重要技术:RCU(Read-Copy-Update)和CAS(Compare-and-Swap)。RCU是一种低开销的读者优先同步机制,适用于大量读者和少量写者的场景。CAS则常用于实现无锁数据结构,如无锁栈和队列。文章提供了相关资源链接以供进一步学习。
摘要由CSDN通过智能技术生成

简单的笔记,未完待续

一道题:

无锁化编程有哪些常见方法?

  • 针对计数器,可以使用原子加
  • 只有一个生产者和一个消费者,那么就可以做到免锁访问环形缓冲区(Ring Buffer)
  • RCU(Read-Copy-Update),新旧副本切换机制,对于旧副本可以采用延迟释放的做法 
  • CAS(Compare-and-Swap),如无锁栈,无锁队列等待

解析:

一、RCU

        RCU是Linux 2.6内核系统新的锁机制 RCU(Read-Copy Update)。参考:http://www.ibm.com/developerworks/cn/linux/l-rcu/

        众所周知,为了保护共享数据,需要一些同步机制,如自旋锁(spinlock),读写锁(rwlock),它们使用起来非常简单,而且是一种很有效的同步机制,在UNIX系统和Linux系统中得到了广泛的使用。但是随着计算机硬件的快速发展,获得这种锁的开销相对于CPU的速度在成倍地增加,原因很简单,CPU的速度与访问内存的速度差距越来越大,而这种锁使用了原子操作指令,它需要原子地访问内存,也就说获得锁

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值