lock-free 相关问题

用于在不使用锁的情况下同步多线程环境或其他形式的分布式系统的方法和算法的总称。

为什么log4j-slf4j-impl不是无锁的?

我在我们的应用程序中在slf4j上使用了异步log4j2,并且我确定这是非阻塞的。但是在集成BlockHound之后,我得到了一个惊喜:java.lang.Exception:[worker-1-8]阻止调用:sun.misc.Unsafe#park ...

回答 1 投票 0

一个单元在哪个级别测试无锁代码?

可以使用LLVM,QEMU,GDB,Bochs,OpenStack等在开源平台上对无锁并发代码进行单元测试吗?有没有人实现过这个?如果您通过推荐软件回答,我不...

回答 1 投票 4

C无锁队列内存管理

为了提高我的C技能,我实现了一个线程安全且无锁的队列。该算法来自Maurice Herlihy和Nir Shavit的“多处理器编程艺术”一书的第10.5章......

回答 2 投票 3

两个unique_ptr的无锁交换

交换两个unique_ptrs并不保证是线程安全的。的std ::的unique_ptr a,b; std :: swap(a,b); //不是threadsafe因为我需要原子指针交换,因为我喜欢所有权......

回答 3 投票 35

带有翻转缓冲器的无锁容器

对于我的一个必须支持并发读写的项目,我需要一个能够缓冲项目的容器,直到消费者一次获取每个当前缓冲的项目。作为生产者......

回答 2 投票 1

boost :: lockfree :: queue(在多线程程序中)是否可锁定?

我正在开发一个程序,其中2+(gstreamer)boost :: threads和一个虚拟应用程序的相同数量的boost :: threads同时使用队列。现在这个队列用于同步......

回答 1 投票 1

可以通过两个boost lockfree队列导致死锁

我的整体设计是让多个生产者线程(> 2)将结果生成为两个原子 processing_done = FALSE; //当所有生产者完成//将设置为true boost :: ...

回答 1 投票 -2

可以检查boost :: lockfree :: queue是否已满?

我正在使用boost :: lockfree :: queue Foo(128)。在弹出队列之前,我可以通过Foo.empty()函数检查队列是否为空状态。我想知道我是否可以同样检查它的状态...

回答 1 投票 0

/boost/lockfree/queue.hpp:错误:静态断言失败:(boost :: has_trivial_destructor ::值)

我试图在此文件中将boost :: lockfree :: queue替换为std :: queue https://github.com/zaphoyd/websocketpp/blob/experimental/examples/broadcast_server/broadcast_server.cpp我添加了#include ...

回答 2 投票 4

无锁进步保证

有趣的是,我发现很多程序员错误地认为“无锁”只意味着“没有互斥的并发编程”。通常,还有一个相关的误解......

回答 6 投票 17

C11无锁乒乓球

我对C语言中的并发性非常陌生,并试图做一些基本的工作人员来理解它是如何工作的。我想编写一个符合无锁定乒乓的实现,即一个线程打印ping,...

回答 1 投票 2

锁定免费的非分配集合

我正在寻找一个集合数据结构:线程安全锁定免费非分配(摊销或预分配是好的)非侵入性不使用外来内在元素顺序不...

回答 1 投票 0

实现多用户无锁队列

最近我遇到了这个问题:有3个消费者线程需要实现一个无锁队列(不能使用同步),这样就不会阻塞消费线程。假设队列......

回答 1 投票 0

是否存在乐观的无锁FIFO队列实现?

是否存在“无锁FIFO队列的optmistic方法”算法的C ++实现(源代码)?

回答 5 投票 10

适用于大阵列的无复制线程安全环形缓冲区

对于大数组(10 ^ 7个元素)上的信号处理,我使用与环形缓冲区连接的不同线程。遗憾的是,只需要太多时间将数据复制到缓冲区和从缓冲区复制数据。目前......

回答 4 投票 4

简单的无锁堆栈c ++ 11

我已经看到几个过于复杂(在我看来很明显)在c ++中使用无锁堆栈的实现(使用这里的标签),我想出了我认为简单但仍然有效的...

回答 2 投票 3

无锁队列

我也在做一个c实现,目前有队列的结构:typedef struct queueelem {queuedata_t data; struct queueelem * next; } queueelem_t; typedef struct queue {...

回答 4 投票 1

无锁队列的C代码

我怎么能在C中实现这个无锁队列伪代码? ENQUEUE(x)q←新记录q ^ .value←x q ^ .next←NULL重复p←tail succ←COMPARE&SWAP(p ^ .next,NULL,...

回答 5 投票 8

C ++ 11中无锁的多生产者/消费者队列

我正在尝试在C ++ 11中实现无锁的多生产者,多消费者队列。我将其作为学习活动进行,因此我很清楚可以使用现有的开放源代码...

回答 4 投票 9

opaque函数调用在编译器优化中意味着什么?

opaque函数调用在编译器优化中意味着什么?我发现它为什么全局变量会导致函数调用中的编译器优化出现问题?和'opaque function call'...

回答 1 投票 0

© www.soinside.com 2019 - 2024. All rights reserved.