用于在不使用锁的情况下同步多线程环境或其他形式的分布式系统的方法和算法的总称。
在带有 RTOS 的单核处理器上使用无锁 spsc 队列时,我们可以像 mpmc 队列一样从多个任务/IRQ 中推送/弹出对象吗? 由于在单核系统上,只有一个任务/IRQ ca...
《C++ Concurrency in Action》第7.15节中无锁队列的push函数中提到的问题
我在《C++ Concurrency in Action》清单 7.15 中读到: 使用引用计数方案可以避免这种特殊的竞争,但这并不是 Push() 中唯一的竞争。如果你看修改后的版本...
据我所知,获取/释放语义充当顺序一致性和较弱内存模型允许的无条件内存重新排序自由之间的中间立场(或“放松”,如......
我在内存数据存储中发现了几种off-heap,比如Chronicle-Map、mapdb等...它们都有锁的使用(stamped读写锁,或者可重入读写锁)。 有数据吗
Mged M. Michael提出的危险指针可以预防ABA问题吗?
更新: 就我而言,“另一个线程可能会删除然后重新插入第 4 行和第 4b 行之间的节点”意味着可以删除、修改节点并将其重新插入到
我正在寻找 C++ 中的无锁数据结构来替换以下内容: pthread_mutex_lock(plock); set.insert(元素); pthread_mutex_unlock(plock); 该集应该支持 .insert() 和 .size()
我正在尝试编写一个有界无锁单生产者、单消费者队列,但是插入队列的元素顺序与从 q 中删除元素的顺序不同...
或者,我们什么时候需要LoadStore屏障? 根据道格·李的说法, (LoadStore) 确保在刷新与 Store2 关联的所有数据和后续存储指令之前加载 Load1 的数据 ...
撕裂的结构值:我应该在多线程读/写场景中始终锁定大型结构吗?
显然,一个变量可能看起来持有一个从未分配给它的值。我在 64 位操作系统上运行了以下程序,针对“AnyCPU”和 .NET Framework 4.5(编辑:虽然它...
在rigtorp的SPSCQueue中使用索引缓存的目的是什么
我正在阅读rigtorp的SPSCQueue的实现,这是一个非常优雅的设计并且具有非常好的基准。 我理解自述文件中描述的大部分设计哲学。我什么...
通常,在原子加载之后使用获取栅栏: if (flag.load(std::memory_order_relaxed)) { std::atomic_thread_fence(std::memory_order_acquire); // 在这里读取一些非原子数据。 } 嗬...
阅读 Jeffrey Richter 在 CLR 中通过 C# 第 4 版创造的 Interlocked Anything 模式,他给出了以下示例,证明我们可以做的不仅仅是 Add for Interlocked 酒吧...
我有两个线程,并且这些线程之间共享了一个浮点类型值。在 Thread1 上写入浮点型值并由 Thread2 读取。 Thread1 和Thread2 同时启动。 私人...
我尝试使用sync.Map + CompareAndSwap来实现无锁并发切片追加,但失败了。 我注意到记录“n”重复出现,但我不明白为什么。 去游乐场 功能主要...
我正在实践 C++ 并发,在尝试理解清单 5.12 时遇到了问题,如下所示(GitHub 代码示例)。我明白为什么以下内容应该在以下情况下起作用:
我正在考虑实现一个无锁循环数组。一个问题是以无锁方式维护头指针和尾指针。我想到的代码是: int 循环增量AndGet(
考虑下面的例子。假设屏障初始化为 0。 有一个生产者线程和两个消费者线程不断检查屏障。如果设置了障碍,它们就会减少 runcnt...
除了主线程之外,我还有一个线程接收数据并将其写入文件中。 std::queue> 数据队列; std::mutex 互斥体; void setData(const std::vecto...
std::atomic<int> 与与本机单词对齐的 int 变量,哪个更好?
#包括 #包括 对齐(sizeof(void*)) int n1; std::atomic n2; int main() { std::thread 线程[32]; for (自动&线程: 线程) {
我尝试使用具有无锁队列的多线程来获得最佳性能来计算素数,而无需编辑朴素的素数检查函数,并且最多仅需要 1.8MB 的 RAM 空间。 关于...