Concurrent priority queue. More...
#include <concurrent_priority_queue.h>
Public Types | |
typedef T | value_type |
Element type in the queue. | |
typedef T & | reference |
Reference type. | |
typedef const T & | const_reference |
Const reference type. | |
typedef size_t | size_type |
Integral type for representing size of the queue. | |
typedef ptrdiff_t | difference_type |
Difference type for iterator. | |
typedef A | allocator_type |
Allocator type. | |
Public Member Functions | |
concurrent_priority_queue (const allocator_type &a=allocator_type()) | |
Constructs a new concurrent_priority_queue with default capacity. | |
concurrent_priority_queue (size_type init_capacity, const allocator_type &a=allocator_type()) | |
Constructs a new concurrent_priority_queue with init_sz capacity. | |
template<typename InputIterator > | |
concurrent_priority_queue (InputIterator begin, InputIterator end, const allocator_type &a=allocator_type()) | |
[begin,end) constructor | |
concurrent_priority_queue (std::initializer_list< T > const &init_list, const allocator_type &a=allocator_type()) | |
Constructor from std::initializer_list. | |
concurrent_priority_queue (const concurrent_priority_queue &src) | |
Copy constructor. More... | |
concurrent_priority_queue (const concurrent_priority_queue &src, const allocator_type &a) | |
Copy constructor with specific allocator. More... | |
concurrent_priority_queue & | operator= (const concurrent_priority_queue &src) |
Assignment operator. More... | |
template<typename InputIterator > | |
void | assign (InputIterator begin, InputIterator end) |
Assign the queue from [begin,end) range, not thread-safe. | |
void | assign (std::initializer_list< T > const &il) |
Assign the queue from std::initializer_list, not thread-safe. | |
concurrent_priority_queue & | operator= (std::initializer_list< T > const &il) |
Assign from std::initializer_list, not thread-safe. | |
bool | empty () const |
Returns true if empty, false otherwise. More... | |
size_type | size () const |
Returns the current number of elements contained in the queue. More... | |
void | push (const_reference elem) |
Pushes elem onto the queue, increasing capacity of queue if necessary. More... | |
bool | try_pop (reference elem) |
Gets a reference to and removes highest priority element. More... | |
void | clear () |
Clear the queue; not thread-safe. More... | |
void | swap (concurrent_priority_queue &q) |
Swap this queue with another; not thread-safe. More... | |
allocator_type | get_allocator () const |
Return allocator object. | |
Concurrent priority queue.
|
inlineexplicit |
Copy constructor.
This operation is unsafe if there are pending concurrent operations on the src queue.
|
inline |
Copy constructor with specific allocator.
This operation is unsafe if there are pending concurrent operations on the src queue.
|
inline |
Clear the queue; not thread-safe.
This operation is unsafe if there are pending concurrent operations on the queue. Resets size, effectively emptying queue; does not free space. May not clear elements added in pending operations.
|
inline |
Returns true if empty, false otherwise.
Returned value may not reflect results of pending operations. This operation reads shared data and will trigger a race condition.
|
inline |
Assignment operator.
This operation is unsafe if there are pending concurrent operations on the src queue.
|
inline |
Pushes elem onto the queue, increasing capacity of queue if necessary.
This operation can be safely used concurrently with other push, try_pop or reserve operations.
|
inline |
Returns the current number of elements contained in the queue.
Returned value may not reflect results of pending operations. This operation reads shared data and will trigger a race condition.
|
inline |
Swap this queue with another; not thread-safe.
This operation is unsafe if there are pending concurrent operations on the queue.
|
inline |
Gets a reference to and removes highest priority element.
If a highest priority element was found, sets elem and returns true, otherwise returns false. This operation can be safely used concurrently with other push, try_pop or reserve operations.