DoubleLi

qq: 517712484 wx: ldbgliet

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  4737 随笔 :: 2 文章 :: 542 评论 :: 1615万 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

转载:http://hi.baidu.com/ah__fu/blog/item/9c5b1236934f84240b55a92b.html


下面是他写的无锁队列的文章:

Michael &Scott 无锁队列 C++ 实现: http://www.cnblogs.com/napoleon_liu/archive/2010/08/07/1794566.html

   这个MS-Queue实现了安全的多个线程入队,多个线程出队。不过因为阶段需要new出来,会有一点影响性能。

GCC 之 cas和cas2:http://www.cnblogs.com/napoleon_liu/articles/2006428.html

   piboye同学实现了原子的比较交换操作。如果是GCC4以上,有福了,GCC的内置函数就有。

   原理上来说,cmpxchg8b这个指令实现了原子的比较和交还。但前面为什么要加LOCK呢?

   LOCK是一个指令的描述符,表示后续的指令在执行的时候,在内存总线上加锁。总线锁会导致其他几个核在一定时钟周期内无法访问内存。虽然总线锁会影响其他核的性能,但比起操作系统级别的锁,已经轻量太多了。

    关于LOCK,这篇帖子讲得很好:lock指令的秘密, http://ooooooo.blogbus.com/logs/1357939.html

多读多写 无锁 lifo 队列:http://www.cnblogs.com/napoleon_liu/archive/2011/04/06/2006547.html

 

    再提供一个template的版本,就更完美了。

posted on   DoubleLi  阅读(481)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示