17 #ifndef GNSS_SDR_CONCURRENT_QUEUE_H 18 #define GNSS_SDR_CONCURRENT_QUEUE_H 21 #include <condition_variable> 32 template <
typename Data>
44 void push(Data
const& data)
46 std::unique_lock<std::mutex> lock(the_mutex);
49 the_condition_variable.notify_one();
54 std::unique_lock<std::mutex> lock(the_mutex);
55 return the_queue.empty();
58 bool try_pop(Data& popped_value)
60 std::unique_lock<std::mutex> lock(the_mutex);
61 if (the_queue.empty())
65 popped_value = the_queue.front();
70 void wait_and_pop(Data& popped_value)
72 std::unique_lock<std::mutex> lock(the_mutex);
73 while (the_queue.empty())
75 the_condition_variable.wait(lock);
77 popped_value = the_queue.front();
81 bool timed_wait_and_pop(Data& popped_value,
int wait_ms)
83 std::unique_lock<std::mutex> lock(the_mutex);
84 if (the_queue.empty())
86 the_condition_variable.wait_for(lock, std::chrono::milliseconds(wait_ms));
87 if (the_queue.empty())
92 popped_value = the_queue.front();
98 std::queue<Data> the_queue;
99 mutable std::mutex the_mutex;
100 std::condition_variable the_condition_variable;
106 #endif // GNSS_SDR_CONCURRENT_QUEUE_H This class implements a thread-safe std::queue.