对于原子变量(atomic),load和store是两个常用的操作。
load操作用于读取原子变量的当前值,它是一个原子操作,确保在读取过程中不会被其他线程的操作干扰。load操作有两种形式:load()和load(memory_order order)。load()默认使用memory_order_seq_cst内存顺序,而load(memory_order order)可以指定不同的内存顺序。
store操作用于将一个值存储到原子变量中,也是一个原子操作。store操作有两种形式:store(value)和store(value, memory_order order)。store(value)默认使用memory_order_seq_cst内存顺序,而store(value, memory_order order)可以指定不同的内存顺序。
load和store操作可以用来实现线程之间的同步和数据的共享。当一个线程调用store操作存储一个值到原子变量中时,其他线程可以通过调用load操作读取到这个值,从而实现线程之间的数据共享。
需要注意的是,load和store操作只能保证对原子变量本身的操作是原子的,而不能保证对原子变量所引用的对象的操作是原子的。如果需要对对象的操作也是原子的,可以考虑使用互斥锁(mutex)或其他同步机制。
下面是一个简单的示例代码,演示了如何使用load和store操作:
#include <iostream>
#include <atomic>
#include <thread>
std::atomic<int> counter(0);
void increment() {
for (int i = 0; i < 100000; ++i) {
counter.store(counter.load() + 1);
}
}
int main() {
std::thread t1(increment);
std::thread t2(increment);
t1.join();
t2.join();
std::cout << "Counter: " << counter.load() << std::endl;
return 0;
}
以上代码创建了两个线程,每个线程都会执行increment函数,该函数通过load和store操作将counter的值加1。最后,主线程输出counter的值,可以看到输出结果是200000,说明load和store操作确保了对counter的原子操作。