You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

106 lines
1.6 KiB

#ifndef CONCURRENTQUEUE_HPP
#define CONCURRENTQUEUE_HPP
#include <queue>
#include <algorithm>
#include "Mutex.hpp"
#include "ConditionVariable.hpp"
#include "ScopedLock.hpp"
#include "Common.hpp"
class CancelledException {};
template <typename T>
class ConcurrentQueue
{
public:
ConcurrentQueue()
: m_queue()
, m_cancelled(false)
, m_mutex()
, m_condVar(m_mutex)
{
TRACE;
}
~ConcurrentQueue()
{
TRACE;
}
void push(const T value)
{
TRACE;
ScopedLock sl(m_mutex);
if (m_cancelled) throw CancelledException();
m_queue.push( value );
m_condVar.signal();
}
bool tryPop(T &popped_value)
{
TRACE;
ScopedLock sl(m_mutex);
if (m_cancelled) throw CancelledException();
if ( m_queue.empty() ) return false;
popped_value = m_queue.front();
m_queue.pop();
return true;
}
T waitAndPop()
{
TRACE;
ScopedLock sl(m_mutex);
while ( m_queue.empty() and not m_cancelled) {
m_condVar.wait();
}
if (m_cancelled) throw CancelledException();
T retVal = m_queue.front(); // cctor
m_queue.pop();
return retVal;
}
bool empty() const
{
TRACE;
ScopedLock sl(m_mutex);
if (m_cancelled) throw CancelledException();
return m_queue.empty();
}
void cancel()
{
TRACE;
ScopedLock sl(m_mutex);
m_cancelled = true;
m_condVar.broadcast();
}
private:
ConcurrentQueue& operator=( const ConcurrentQueue& );
ConcurrentQueue( const ConcurrentQueue& );
std::queue<T> m_queue;
bool m_cancelled;
mutable Mutex m_mutex;
ConditionVariable m_condVar;
};
#endif // CONCURRENTQUEUE_HPP