在C++中,可以使用互斥鎖(mutex)來實(shí)現(xiàn)線程安全的get和set操作。互斥鎖可以確保在多線程環(huán)境下同一時間只有一個線程可以訪問某個共享資源,從而避免多線程同時訪問導(dǎo)致的數(shù)據(jù)競爭問題。
以下是一個簡單的示例代碼,展示如何使用互斥鎖來實(shí)現(xiàn)線程安全的get和set操作:
#include <iostream>
#include <thread>
#include <mutex>
class MyClass {
public:
void set(int value) {
std::lock_guard<std::mutex> lock(mutex);
data = value;
}
int get() {
std::lock_guard<std::mutex> lock(mutex);
return data;
}
private:
int data;
std::mutex mutex;
};
int main() {
MyClass obj;
std::thread t1([&obj](){
for (int i = 0; i < 1000; ++i) {
obj.set(obj.get() + 1);
}
});
std::thread t2([&obj](){
for (int i = 0; i < 1000; ++i) {
obj.set(obj.get() + 1);
}
});
t1.join();
t2.join();
std::cout << "Final value: " << obj.get() << std::endl;
return 0;
}
在上面的示例中,我們創(chuàng)建了一個MyClass
類,其中包含一個私有成員變量data
和一個std::mutex
類型的互斥鎖mutex
。在set
和get
方法中,我們使用std::lock_guard
來對互斥鎖進(jìn)行加鎖和解鎖操作,確保只有一個線程可以訪問data
成員變量。
在main
函數(shù)中,我們創(chuàng)建了兩個線程t1
和t2
,分別對obj
對象的data
成員變量進(jìn)行加1操作。通過使用互斥鎖,我們保證了兩個線程對data
的訪問是線程安全的,最終輸出的Final value
應(yīng)該是2000。