并发写入同一缓存行中的不同位置

时间:2013-02-01 06:58:23

标签: c++ caching concurrency c++11 memory-model

假设我有一个C ++ 11应用程序,其中两个线程使用指向原始类型的简单指针写入不同但附近的内存位置。我能否确定这两个写入最终都会在内存中结束(可能在两者都达到boost::barrier之后),或者存在两个CPU核心都拥有包含该数据的自己的缓存行的风险,以及第二个核心将其修改刷新到RAM将覆盖并撤消第一次写入所做的修改?

我希望缓存一致性会在所有情况下以及符合C ++ 11内存模型的所有设置中为我处理这个问题,但我想确定。

1 个答案:

答案 0 :(得分:7)

是的缓存一致性机制将负责这一点。这称为False sharing,应该通过更好地分离数据来提高性能来避免这种情况。