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 > 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... | |
| concurrent_priority_queue (concurrent_priority_queue &&src) | |
| Move constructor.  More... | |
| concurrent_priority_queue (concurrent_priority_queue &&src, const allocator_type &a) | |
| Move constructor with specific allocator.  More... | |
| concurrent_priority_queue & | operator= (concurrent_priority_queue &&src) | 
| Move 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 > il) | 
| Assign the queue from std::initializer_list, not thread-safe. | |
| concurrent_priority_queue & | operator= (std::initializer_list< T > 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... | |
| void | push (value_type &&elem) | 
| Pushes elem onto the queue, increasing capacity of queue if necessary.  More... | |
| template<typename... Args> | |
| void | emplace (Args &&...args) | 
| Constructs a new element using args as the arguments for its construction and pushes it onto the queue */.  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 | 
Move constructor.
This operation is unsafe if there are pending concurrent operations on the src queue.
| 
 | inline | 
Move 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 | 
Constructs a new element using args as the arguments for its construction and pushes it onto the queue */.
This operation can be safely used concurrently with other push, try_pop or emplace 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 | 
Move 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 emplace operations.
| 
 | 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 emplace 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 emplace operations.