您好,登錄后才能下訂單哦!
在 Linux 中,使用 C++ 實現線程安全隊列需要考慮以下幾點:
下面是一個簡單的線程安全隊列實現:
#include <iostream>
#include <queue>
#include <mutex>
#include <condition_variable>
#include <thread>
template <typename T>
class ThreadSafeQueue {
public:
// 入隊操作
void push(const T& item) {
std::unique_lock<std::mutex> lock(mutex_);
queue_.push(item);
lock.unlock();
cond_.notify_one();
}
// 出隊操作
bool pop(T& item) {
std::unique_lock<std::mutex> lock(mutex_);
while (queue_.empty()) {
cond_.wait(lock);
}
item = queue_.front();
queue_.pop();
return true;
}
// 判斷隊列是否為空
bool empty() const {
std::lock_guard<std::mutex> lock(mutex_);
return queue_.empty();
}
private:
std::queue<T> queue_;
mutable std::mutex mutex_;
std::condition_variable cond_;
};
void producer(ThreadSafeQueue<int>& queue) {
for (int i = 0; i < 10; ++i) {
queue.push(i);
std::cout << "Produced: "<< i << std::endl;
}
}
void consumer(ThreadSafeQueue<int>& queue) {
int item;
for (int i = 0; i < 10; ++i) {
while (!queue.pop(item)) {
std::cout << "Consumed: Waiting for item" << std::endl;
}
std::cout << "Consumed: " << item << std::endl;
}
}
int main() {
ThreadSafeQueue<int> queue;
std::thread producer_thread(producer, std::ref(queue));
std::thread consumer_thread(consumer, std::ref(queue));
producer_thread.join();
consumer_thread.join();
return 0;
}
這個實現中,我們使用了 std::queue
來存儲數據,std::mutex
來保護隊列,以及 std::condition_variable
來同步線程間的操作。生產者線程將元素添加到隊列中,消費者線程從隊列中取出元素。當隊列為空時,消費者線程會等待生產者線程添加元素;當隊列已滿時,生產者線程會等待消費者線程取出元素。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。