[英]How to make push and pop on queue atomic, how to lock those operations?
我正在使用队列进行两个线程之间的通信(一个只生成自定义类的实例并将指针推送到队列,另一个从自定义类的队列指针读取并进行一些计算)。 如何在队列原子上进行推送和弹出,如何锁定那些操作?(我不能使用C ++ 11标准)
可移植性最强的非C ++ 11锁定机制可能是Boost.Thread库中的同步类型。 特别是, mutex类为您提供了一个简单的可锁定对象,用于提供对资源的独占访问。 例如:
#include <boost/thread/mutex.hpp>
#include <queue>
template <typename T>
class locking_queue {
public:
void push(T const & value) {
boost::mutex::scoped_lock lock(mutex);
queue.push(value);
}
bool pop(T & value) {
boost::mutex::scoped_lock lock(mutex);
if (queue.empty()) {
return false;
} else {
value = queue.front();
queue.pop();
return true;
}
}
private:
std::queue<T> queue;
boost::mutex mutex;
};
另一个优点是,这与C ++ 11 std::mutex
类非常相似,如果您决定使用它,这将使转换变得非常简单。
这是一个伪代码:
// Thread A
mutex.lock();
q.push();
mutex.unlock();
// Thread B
mutex.lock();
q.pop();
mutex.unlock();
如果你正在使用boost,你可以试试它的互斥类。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.