std::atomic_thread_fence是C++中的一个原子操作,用于在多线程环境下提供内存序的同步。
以下是一个可运行的代码示例,展示了如何使用 std::atomic_thread_fence 来保证内存顺序:
#include <iostream>
#include <thread>
#include <atomic>
std::atomic<int> x(0);
std::atomic<int> y(0);
void thread1() {
x.store(1, std::memory_order_relaxed);
std::atomic_thread_fence(std::memory_order_release);
int val = y.load(std::memory_order_acquire);
std::cout << "Thread 1: y = " << val << std::endl;
}
void thread2() {
y.store(1, std::memory_order_relaxed);
std::atomic_thread_fence(std::memory_order_release);
int val = x.load(std::memory_order_acquire);
std::cout << "Thread 2: x = " << val << std::endl;
}
int main() {
std::thread t1(thread1);
std::thread t2(thread2);
t1.join();
t2.join();
return 0;
}
这个代码示例中,两个线程分别修改和读取 x 和 y 的值。通过在适当的地方插入 std::atomic_thread_fence 调用,并指定合适的内存顺序参数(如 std::memory_order_release 和 std::memory_order_acquire),确保了正确的同步和内存顺序。
内容由零声教学AI助手提供,问题来源于学员提问




