gpt4 book ai didi

c++ - 高效的内存屏障

转载 作者:IT王子 更新时间:2023-10-29 01:24:45 26 4
gpt4 key购买 nike

我有一个多线程应用程序,其中每个线程都有一个整数类型的变量。这些变量在程序执行期间递增。在代码中的某些点,线程将其计数变量与其他线程的计数变量进行比较。

既然我们知道在多核上运行的线程可能会乱序执行,一个线程可能不会读取其他线程的预期计数器值。要解决这个问题,一种方法是使用原子变量,比如C++11的std::atomic<>。但是,在每次计数器递增时执行内存栅栏会显着降低程序速度。

现在我想做的是,当一个线程即将读取其他线程的计数器时,才创建一个内存栅栏,并在此时更新内存中所有线程的计数器。如何在 C++ 中完成此操作。我正在使用 Linux 和 g++。

最佳答案

C++11 标准库在 <atomic> 中包含对栅栏的支持与 std::atomic_thread_fence .

调用它会调用一个完整的栅栏:

std::atomic_thread_fence(std::memory_order_seq_cst);

如果你只想发出一个获取或只发出一个释放栅栏,你可以使用std:memory_order_acquirestd::memory_order_release相反。

关于c++ - 高效的内存屏障,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7346163/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com