亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux C++多線程編程中的線程安全隊列實現

發布時間:2024-11-18 09:55:15 來源:億速云 閱讀:82 作者:小樊 欄目:編程語言

在 Linux 中,使用 C++ 實現線程安全隊列需要考慮以下幾點:

  1. 使用互斥鎖(mutex)保護共享資源,確保同一時間只有一個線程可以訪問隊列。
  2. 使用條件變量(condition variable)來同步線程間的操作,例如當隊列為空時,等待其他線程添加元素;當隊列已滿時,等待其他線程取出元素。
  3. 使用原子操作(atomic operations)來避免不必要的鎖競爭。

下面是一個簡單的線程安全隊列實現:

#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 來同步線程間的操作。生產者線程將元素添加到隊列中,消費者線程從隊列中取出元素。當隊列為空時,消費者線程會等待生產者線程添加元素;當隊列已滿時,生產者線程會等待消費者線程取出元素。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

杨浦区| 新郑市| 石首市| 新蔡县| 隆子县| 卫辉市| 新沂市| 廊坊市| 昌平区| 石河子市| 旬阳县| 德格县| 茶陵县| 新巴尔虎右旗| 浦江县| 天峨县| 新平| 绥中县| 扎囊县| 木里| 涞水县| 宁远县| 康马县| 宁强县| 三都| 盈江县| 临泽县| 平谷区| 景宁| 金平| 镇宁| 黎平县| 尉氏县| 新巴尔虎右旗| 公主岭市| 定州市| 苍溪县| 新乡县| 崇文区| 开封县| 酉阳|