您的位置:首页 > 房产 > 家装 > C++ Thead多线程 condition_variable 与其使用场景---C++11多线程快速学习

C++ Thead多线程 condition_variable 与其使用场景---C++11多线程快速学习

2024/10/5 18:28:22 来源:https://blog.csdn.net/weijia3624/article/details/139988583  浏览:    关键词:C++ Thead多线程 condition_variable 与其使用场景---C++11多线程快速学习

std::condition_variable 的步骤如下:

  1. 创建一个 std::condition_variable 对象。

  2. 创建一个互斥锁 std::mutex 对象,用来保护共享资源的访问。

  3. 在需要等待条件变量的地方

    使用 std::unique_lock<std::mutex> 对象锁定互斥锁

    并调用 std::condition_variable::wait()std::condition_variable::wait_for() 或 std::condition_variable::wait_until() 函数等待条件变量。

  4. 在其他线程中需要通知等待的线程时,调用 std::condition_variable::notify_one() 或 std::condition_variable::notify_all() 函数通知等待的线程。

生产者与消费者模型

下面是一个简单的生产者-消费者模型的案例,其中使用了 `std::condition_variable` 来实现线程的等待和通知机制:

#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>
#include <queue>
std::mutex g_mutex;
std::condition_variable g_cv;
std::queue<int> g_queue;void Producer() {for (int i = 0; i < 10; i++) {{            std::unique_lock<std::mutex> lock(g_mutex);g_queue.push(i);            std::cout << "Producer: produced " << i << std::endl;}g_cv.notify_one();        std::this_thread::sleep_for(std::chrono::milliseconds(100));}
}
void Consumer() {    while (true) {        std::unique_lock<std::mutex> lock(g_mutex);g_cv.wait(lock, []() { return !g_queue.empty(); });        int value = g_queue.front();g_queue.pop();        std::cout << "Consumer: consumed " << value << std::endl;}
}
int main() {    std::thread producer_thread(Producer);    std::thread consumer_thread(Consumer);producer_thread.join();consumer_thread.join();    return 0;
}

使用 `std::condition_variable` 可以实现线程的等待和通知机制,从而在多线程环境中实现同步操作。在生产者-消费者模型中,使用 `std::condition_variable` 可以让消费者线程等待生产者线程生产数据后再进行消费,避免了数据丢失或者数据不一致的问题。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com