- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对这两个概念有点困惑。
维基上无锁的定义:
A non-blocking algorithm is lock-free if there is guaranteed system-wide progress
an algorithm is called non-blocking if failure or suspension of any thread cannot cause failure or suspension of another thread
"spinlock is not lock-free"
对我来说也很有意义。就像,如果持有自旋锁的线程被挂起,那么它会导致其他在外面旋转的线程被挂起。所以,根据定义,
spinlock
甚至不是非阻塞的,更不用说无锁了。
最佳答案
任何可以称为锁的东西(在当前线程解锁之前从临界区中排除其他线程)都不是无锁的。是的,自旋锁是一种锁。
如果一个线程在持有锁时休眠,则没有其他线程可以获取它并向前推进,而自旋锁无法阻止这种情况。操作系统可以随时取消调度线程,即使它处于临界区的中间。
请注意,“无锁”与“无等待”不同,因此无锁算法仍然可以有像 cmpxchg 重试循环这样的东西,但只要一个线程每次都成功,它就是无锁的。
无等待算法甚至不能做到这一点,最多必须等待竞争原子操作的缓存未命中/硬件仲裁。维基百科的non-blocking algorithm article更详细地定义了无等待和无锁。
我认为您混淆了“阻塞”的两个定义。
我认为您在谈论 spin_trylock
尝试获取自旋锁的函数 , 如果它失败而不是旋转,则返回错误。因此,这是与非阻塞 I/O 相同意义上的非阻塞:因错误而失败,而不是等待资源可用性。
这并不意味着系统中的任何线程在受自旋锁保护的事物上取得进展。 这只是意味着您的线程可以在再次尝试之前去做其他事情,而不是需要使用单独的线程来与等待获取锁并行执行某些操作。
在无限循环中旋转算作阻塞/不进展。对于这个定义,纯自旋锁和(在操作系统帮助下)休眠直到另一个线程解锁的自旋锁之间没有区别。
无锁的定义与浪费 CPU 时间/功率来为独立工作腾出空间无关。
有点相关:获取无竞争的自旋锁不需要系统调用,这意味着它是一个“轻量级”锁。即使在无竞争的情况下,一些锁实现也总是使用(相对较慢的)系统调用。见 Jeff Preshing's Always Use a Lightweight Mutex文章。另请阅读 Jeff 的其他帖子以了解有关无锁编程的更多信息,因为它们非常出色。事实上,[无锁] 标签维基链接到它们非常好。
关于multithreading - 自旋锁是免费的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41146527/
前言 俗话说得好“工欲善其事,必先利其器”,合理的选择和使用可视化的管理工具可以降低技术入门和使用的门槛。今天大姚给大家分享一款.NET Avalonia开源、免费、跨平台、快速的Git可视化管理工
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 9年前关闭。 Improve this que
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
正在学习有关 C 语言链接列表的教程。我已编译此代码并通过 valgrind 运行它。它显示了 4 次分配和 0 次释放,这是我理解的。我需要知道如何正确调用 free() 来释放分配。 代码示例:l
正如标题所说,我需要一个搜索引擎...用于mysql 搜索。我的网站是基于 PHP 的。 我打算使用 sphinx,但我的托管公司不支持全文索引! 所以一个没有全文的搜索引擎! 它应该是相当强大的,并
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 2 年前。
我正在寻找稳定和成熟的免费/开源库来比较两个图像。 我找到了这个,但我想知道你是否使用更好的! Similar images finder - .NET Image processing in C#
我有一个通用链表实现,其中包含一个指向数据的 void* 的节点结构和一个包含对头的引用的列表结构。现在这是我的问题,链表中的一个节点可能通过其 void* 持有对另一个链表的引用。当我释放包含较小列
前言 今天大姚给大家分享一款开源(MIT License)、免费、现代化风格的WPF UI控件库:ModernWpf。 项目介绍 ModernWpf是一个开源项目,它为 WPF 提供了一组现代化
LiveCharts2 LiveCharts2是一个.NET开源(MIT License)、简单、灵活、交互式且功能强大的.NET图表、地图和仪表,现在几乎可以在任何地方运行如:Maui、Uno P
前言 今天大姚给大家分享一款.NET开源(MIT License)、免费、实用的多功能原神工具箱,旨在改善桌面端玩家的游戏体验:胡桃工具箱。 工具箱介绍 胡桃工具箱是一款.NET开源(MIT
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 3年前关闭。 Improve this qu
当我这样做时,我的 meteor 应用程序运行的免费服务器的规范是什么。 meteor deploy myapp.meteor.com 规范方面 Storage size Max bandwidth
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
如果可能,我可以使用任何网络服务免费存储少量数据(考虑 XML 或 JSON)? 我想我想创建一个小型待办事项应用程序,只是探索/学习(最好是免费的),它还可以将数据备份到云端,以便他们可以在智能手机
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 2年前关闭。 Improve this qu
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
是否有任何免费/开源替代 Codesmith 可以在功能上进行比较并生成 .NET 代码? 最佳答案 几年前我做了同样的研究,发现 MyGeneration 成为 非常好。 关于.net - 免费 C
在尝试找到可以逐步执行/允许线程的haskell monad时,我发现了免费的monad data Free f a = Return a | Roll (f (Free f a)) 及其 monad
我是一名优秀的程序员,十分优秀!