您好,登錄后才能下訂單哦!
在 Linux 中,使用 C++ 實(shí)現(xiàn)線程間的安全數(shù)據(jù)交換通常需要使用互斥鎖(mutex)和條件變量(condition variable)
#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>
#include <vector>
std::mutex mtx; // 全局互斥鎖
std::condition_variable cv; // 全局條件變量
int shared_data = 0; // 共享數(shù)據(jù)
// 生產(chǎn)者線程函數(shù)
void producer() {
for (int i = 0; i < 10; ++i) {
std::unique_lock<std::mutex> lock(mtx); // 獲取互斥鎖
shared_data += 1; // 修改共享數(shù)據(jù)
std::cout << "Producer: " << shared_data << std::endl;
cv.notify_one(); // 通知消費(fèi)者線程
lock.unlock(); // 釋放互斥鎖
std::this_thread::sleep_for(std::chrono::milliseconds(100)); // 模擬耗時(shí)操作
}
}
// 消費(fèi)者線程函數(shù)
void consumer() {
while (true) {
std::unique_lock<std::mutex> lock(mtx); // 獲取互斥鎖
cv.wait(lock, []{ return shared_data > 0; }); // 等待條件變量滿足
std::cout << "Consumer: " << shared_data << std::endl;
shared_data = 0; // 重置共享數(shù)據(jù)
lock.unlock(); // 釋放互斥鎖
}
}
int main() {
std::thread producer_thread(producer); // 創(chuàng)建生產(chǎn)者線程
std::thread consumer_thread(consumer); // 創(chuàng)建消費(fèi)者線程
producer_thread.join(); // 等待生產(chǎn)者線程結(jié)束
consumer_thread.join(); // 等待消費(fèi)者線程結(jié)束
return 0;
}
在這個(gè)示例中,我們使用了一個(gè)全局互斥鎖 mtx
和一個(gè)全局條件變量 cv
來(lái)確保線程間的安全數(shù)據(jù)交換。生產(chǎn)者線程在修改共享數(shù)據(jù)之前需要獲取互斥鎖,修改完成后通知消費(fèi)者線程。消費(fèi)者線程在等待條件變量滿足(即共享數(shù)據(jù)大于 0)之前需要獲取互斥鎖。當(dāng)條件滿足時(shí),消費(fèi)者線程可以安全地訪問(wèn)共享數(shù)據(jù),然后重置共享數(shù)據(jù)并繼續(xù)等待。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。