7得票3回答
顺序之前的修改顺序一致性

来自 http://en.cppreference.com : 松散排序 带有 std::memory_order_relaxed 标签的原子操作不是同步操作,它们不会对内存进行排序。它们只保证原子性和修改顺序一致性。例如,当 x 和 y 最初为零时, // Thread 1: r1 = ...

26得票2回答
C++11:memory_order_relaxed和memory_order_consume的区别

我正在学习C++11内存顺序模型,并想了解memory_order_relaxed和memory_order_consume之间的区别。 具体来说,我正在寻找一个简单的例子,其中不能用memory_order_relaxed替换memory_order_consume。 有一篇优秀的文章详...

11得票2回答
将指向原子类型的指针分配给指向非原子类型的指针

这段代码的行为是否定义良好?#include <stdatomic.h> const int test = 42; const int * _Atomic atomic_int_ptr; atomic_init(&atomic_int_ptr, &test); c...

12得票2回答
我可以直接在原子变量上执行算术运算吗?

我能直接在原子变量上执行算术操作吗?由于我发现C标准库提供了许多实用函数,如atomic_fetch_add,用于在原子变量和非原子变量之间执行加法。但是,我很好奇,既然变量是原子的,我能否直接对其进行算术运算?就像下面展示的代码一样:#include <threads.h> #i...

9得票4回答
C11/C++11弱内存模型基准测试

有没有人可以提供比较使用松散原子操作(特别是memory_order_release和memory_order_acquire,以及memory_order_consume和memory_order_relaxed)与默认的memory_order_seq_cst的C11/C++11代码性能基...

7得票2回答
这个信封实现是否正确使用了C++11原子类型?

我写了一个简单的“envelope”类,以确保我正确理解C++11原子语义。该类有一个头部和一个负载,写入者会清除头部,填充负载,然后用递增整数填充头部。读取者可以读取头部,memcpy出负载,再次读取头部,并且如果头部相同,则可以假定成功地复制了负载。读取者可能会错过一些更新,但获取到混合不...

35得票1回答
C++11中memory_order_acquire和memory_order_release的语义是什么?

http://en.cppreference.com/w/cpp/atomic/memory_order和其他C++11在线参考资料定义了memory_order_acquire和memory_order_release: Acquire操作:在此次加载之前,当前线程中没有读取可以被重新排...

12得票2回答
C++11是否保证在释放栅栏和消费操作之间有内存顺序?

请考虑以下代码:struct payload { std::atomic< int > value; }; std::atomic< payload* > pointer( nullptr ); void thread_a() { payload* ...

10得票2回答
当类型不是整数时,如何使用std::atomic执行基本操作?

准确来说,我只需要将一个 double 增加另一个 double,并希望它是线程安全的。我不想使用互斥锁,因为执行速度会急剧下降。

13得票1回答
什么时候应该使用std::atomic_compare_exchange_strong?

在C++11中有两个原子的CAS操作:atomic_compare_exchange_weak和atomic_compare_exchange_strong。 根据cppreference: 弱版本的函数可能会出现虚假失败,即使它们相等也可能如*obj != *expected。当比较和交...