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

溫馨提示×

C++線程類如何處理線程間的通信

c++
小樊
96
2024-08-29 22:43:10
欄目: 編程語言

在C++中,可以使用標準庫中的std::thread類來創建和管理線程。為了實現線程間的通信,你可以使用以下方法:

  1. 使用互斥鎖(std::mutex)和條件變量(std::condition_variable):

互斥鎖用于保護共享數據,確保同一時間只有一個線程能訪問共享數據。條件變量用于線程間的同步,當一個線程需要等待另一個線程更新共享數據時,可以使用條件變量。

#include<iostream>
#include<thread>
#include <mutex>
#include<condition_variable>

std::mutex mtx;
std::condition_variable cv;
int shared_data = 0;

void thread1() {
    std::unique_lock<std::mutex> lock(mtx);
    shared_data = 42;
    cv.notify_one();
}

void thread2() {
    std::unique_lock<std::mutex> lock(mtx);
    cv.wait(lock, [] { return shared_data == 42; });
    std::cout << "Thread 2 received data: "<< shared_data<< std::endl;
}

int main() {
    std::thread t1(thread1);
    std::thread t2(thread2);

    t1.join();
    t2.join();

    return 0;
}
  1. 使用原子操作(std::atomic):

原子操作是線程安全的,可以在不使用互斥鎖的情況下實現線程間的通信。原子操作提供了一種在多線程環境中安全地訪問共享數據的方式。

#include<iostream>
#include<thread>
#include<atomic>

std::atomic<int> shared_data(0);

void thread1() {
    shared_data.store(42, std::memory_order_release);
}

void thread2() {
    int value = shared_data.load(std::memory_order_acquire);
    std::cout << "Thread 2 received data: "<< value<< std::endl;
}

int main() {
    std::thread t1(thread1);
    std::thread t2(thread2);

    t1.join();
    t2.join();

    return 0;
}
  1. 使用消息隊列或其他數據結構:

你還可以使用消息隊列、阻塞隊列或其他數據結構來實現線程間的通信。例如,可以使用std::queuestd::mutex來實現一個簡單的生產者-消費者模型。

#include<iostream>
#include<thread>
#include<queue>
#include <mutex>
#include<condition_variable>

std::queue<int> message_queue;
std::mutex mtx;
std::condition_variable cv;

void producer() {
    for (int i = 0; i < 10; ++i) {
        std::unique_lock<std::mutex> lock(mtx);
        message_queue.push(i);
        cv.notify_one();
    }
}

void consumer() {
    while (true) {
        std::unique_lock<std::mutex> lock(mtx);
        cv.wait(lock, [] { return !message_queue.empty(); });
        int message = message_queue.front();
        message_queue.pop();
        if (message == -1) {
            break;
        }
        std::cout << "Received message: "<< message<< std::endl;
    }
}

int main() {
    std::thread t1(producer);
    std::thread t2(consumer);

    t1.join();

    {
        std::unique_lock<std::mutex> lock(mtx);
        message_queue.push(-1);
        cv.notify_one();
    }

    t2.join();

    return 0;
}

這些方法可以幫助你實現C++線程間的通信。選擇合適的方法取決于你的具體需求和場景。

0
遵义市| 彝良县| 成安县| 铜川市| 陇川县| 米脂县| 宜黄县| 静海县| 普宁市| 尼勒克县| 上犹县| 仁怀市| 乌苏市| 桐庐县| 宁远县| 洪湖市| 万源市| 璧山县| 雷山县| 通海县| 阜南县| 高淳县| 忻州市| 南郑县| 汨罗市| 望江县| 旬邑县| 新密市| 秦安县| 河池市| 中超| 鹿邑县| 武汉市| 兴海县| 乐平市| 介休市| 虞城县| 玛纳斯县| 四平市| 武穴市| 华坪县|