std::experimental::pmr::synchronized_pool_resource (3) - Linux Manuals
Defined in header <experimental/memory_resource>
class synchronized_pool_resource : public memory_resource; (library fundamentals TS)
The class std::experimental::pmr::synchronized_pool_resource is a general-purpose memory resource class with the following properties:
* It owns the allocated memory and frees it on destruction, even if deallocate has not been called for some of the allocated blocks.
* It consists of a collection of pools that serves request for different block sizes. Each pool manages a collection of chunks that are then divided into blocks of uniform size.
* Calls to do_allocate are dispatched to the pool serving the smallest blocks accommodating the requested size.
* Exhausting memory in the pool causes the next allocation request for that pool to allocate an additional chunk of memory from the upstream allocator to replenish the pool. The chunk size obtained increases geometrically.
* Allocations requests that exceed the largest block size are served from the upstream allocator directly.
* The largest block size and maximum chunk size may be tuned by passing a std::experimental::pmr::pool_options struct to its constructor.
synchronized_pool_resource may be accessed from multiple threads without external synchronization, and may have thread-specific pools to reduce synchronization costs. If the memory resource is only accessed from one thread, unsynchronized_pool_resource is more efficient.
constructor (public member function)
destructor Destroys a synchronized_pool_resource, releasing all allocated memory
operator= Copy assignment operator is deleted. synchronized_pool_resource is not copy assignable
Public member functions
release (public member function)
upstream_resource (public member function)
options (public member function)
Protected member functions
do_allocate Allocate memory
do_deallocate Return memory to the pool
do_is_equal Compare for equality with another memory_resource