7

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

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

4

1 回答 1

8

是的,缓存一致性机制会解决这个问题。这称为虚假共享,应通过更好地分离数据以提高性能来避免这种情况。

于 2013-02-01T07:09:28.193 回答