std::condition_variable 需与 std::unique_lock 配合使用,通过 wait() 释放锁并等待,由 notify_one() 或 notify_all() 唤醒;常用带谓词的 wait 防止虚假唤醒,适用于生产者-消费者等场景,需注意在循环中检查条件、避免丢失唤醒和死锁,并在退出时通知所有线程。

在C++多线程编程中,std::condition_variable 是实现线程间协调与同步的重要工具之一。它通常配合 std::mutex 使用,用于阻塞一个或多个线程,直到某个条件成立才被唤醒继续执行。这种机制特别适用于生产者-消费者模型、任务队列、资源等待等场景。
std::condition_variable 的核心思想是“等待某个条件为真”。线程在条件不满足时进入等待状态,释放持有的互斥锁,避免忙等;当其他线程修改了共享状态并通知时,等待的线程被唤醒,重新获取锁并检查条件是否已满足。
关键点:
std::condition_variable 提供以下几个主要接口:
立即学习“C++免费学习笔记(深入)”;
下面是一个简单的线程安全队列,展示 condition_variable 如何实现同步:
<pre class="brush:php;toolbar:false;">#include <thread>
#include <queue>
#include <mutex>
#include <condition_variable>
#include <iostream>
template<typename T>
class SafeQueue {
private:
std::queue<T> data_;
std::mutex mtx_;
std::condition_variable cv_;
bool stopped_ = false;
public:
void push(T value) {
std::lock_guard<std::mutex> lock(mtx_);
data_.push(std::move(value));
cv_.notify_one(); // 通知一个消费者
}
bool pop(T& value) {
std::unique_lock<std::mutex> lock(mtx_);
cv_.wait(lock, [this] { return !data_.empty() || stopped_; });
if (data_.empty()) return false;
value = std::move(data_.front());
data_.pop();
return true;
}
void stop() {
std::lock_guard<std::mutex> lock(mtx_);
stopped_ = true;
cv_.notify_all();
}
};
在这个例子中,消费者线程调用 pop 时若队列为空,会自动阻塞等待。生产者调用 push 后通过 notify_one 唤醒一个消费者。使用谓词形式的 wait 可防止虚假唤醒导致错误退出。
正确使用 condition_variable 要注意以下几点:
基本上就这些。std::condition_variable 是C++并发编程中实现高效线程同步的关键组件,掌握其工作原理和正确用法,能有效解决复杂多线程协作问题。不复杂但容易忽略细节,尤其是对虚假唤醒和锁管理的处理。
以上就是c++++中std::condition_variable如何实现线程同步_c++条件变量同步机制详解的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号