下面是一个演示如何使用 std::atomic
对复杂数据类型进行原子操作的 C++ 示例代码。这里使用 std::atomic<std::shared_ptr<T>>
来保证对共享指针的原子操作,适用于管理复杂数据结构的情形。
#include <atomic>
#include <memory>
#include <iostream>
struct ComplexData {
int value1;
double value2;
std::string value3;
ComplexData(int v1, double v2, std::string v3)
: value1(v1), value2(v2), value3(v3) {}
};
std::atomic<std::shared_ptr<ComplexData>> dataPtr;
void updateData(int v1, double v2, const std::string& v3) {
// 为新数据创建一个shared_ptr
std::shared_ptr<ComplexData> newData = std::make_shared<ComplexData>(v1, v2, v3);
// 原子地替换旧数据
std::atomic_store(&dataPtr, newData);
}
void processData() {
// 原子地读取共享指针
std::shared_ptr<ComplexData> data = std::atomic_load(&dataPtr);
if (data) {
std::cout << "Current Data: " << data->value1 << ", " << data->value2 << ", " << data->value3 << std::endl;
} else {
std::cout << "Data pointer is null." << std::endl;
}
}
int main() {
updateData(10, 20.5, "Test Data");
processData();
return 0;
}
在这个代码中:
ComplexData
结构体用于存储一个整数、一个双精度浮点数和一个字符串。dataPtr
是一个原子性的std::shared_ptr<ComplexData>
,用于确保对复杂数据的线程安全访问。updateData
函数创建一个新的ComplexData
实例,并原子性地替换旧数据。processData
函数原子性地读取数据并打印。
这样,即使在多线程环境中,对 dataPtr
的访问也是安全的,避免了数据竞争的问题。