|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bslma::Allocator *basicAllocator=0) |
|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bsls::BlockGrowth::Strategy growthStrategy, bslma::Allocator *basicAllocator=0) |
|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bsls::Alignment::Strategy alignmentStrategy, bslma::Allocator *basicAllocator=0) |
|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bsls::BlockGrowth::Strategy growthStrategy, bsls::Alignment::Strategy alignmentStrategy, bslma::Allocator *basicAllocator=0) |
|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bsls::Types::size_type maxBufferSize, bslma::Allocator *basicAllocator=0) |
|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bsls::Types::size_type maxBufferSize, bsls::BlockGrowth::Strategy growthStrategy, bslma::Allocator *basicAllocator=0) |
|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bsls::Types::size_type maxBufferSize, bsls::Alignment::Strategy alignmentStrategy, bslma::Allocator *basicAllocator=0) |
|
| BufferedSequentialPool (char *buffer, bsls::Types::size_type size, bsls::Types::size_type maxBufferSize, bsls::BlockGrowth::Strategy growthStrategy, bsls::Alignment::Strategy alignmentStrategy, bslma::Allocator *basicAllocator=0) |
|
| ~BufferedSequentialPool () |
|
void * | allocate (bsls::Types::size_type size) |
|
template<class TYPE > |
void | deleteObject (const TYPE *object) |
|
template<class TYPE > |
void | deleteObjectRaw (const TYPE *object) |
|
void | release () |
|
void | rewind () |
|
bslma::Allocator * | allocator () const |
|
This class implements a fast memory pool that efficiently dispenses heterogeneous blocks of memory (of varying, user-specified sizes) from an external buffer whose address and size (in bytes) are supplied at construction. If an allocation request exceeds the remaining free memory space in the external buffer, memory will be supplied by an (optional) allocator supplied also at construction; if no allocator is supplied, the currently installed default allocator will be used. This class is exception neutral: If memory cannot be allocated, the behavior is defined by the (optional) allocator supplied at construction. Note that in no case will the buffered sequential pool attempt to deallocate the external buffer.
See bdlma_bufferedsequentialpool
Create a buffered sequential pool for allocating memory blocks from the specified external buffer
having the specified size
(in bytes), or from an internal buffer (after the external buffer
is exhausted). Optionally specify a growthStrategy
used to control buffer growth. If a growthStrategy
is not specified, geometric growth is used. Optionally specify an alignmentStrategy
used to align allocated memory blocks. If an alignmentStrategy
is not specified, natural alignment is used. Optionally specify a basicAllocator
used to supply memory should the capacity of buffer
be exhausted. If basicAllocator
is 0, the currently installed default allocator is used. The behavior is undefined unless 0 < size
, and buffer
has at least size
bytes. Note that, due to alignment effects, it is possible that not all size
bytes of memory in buffer
can be used for allocation. Also note that no limit is imposed on the size of the internal buffers when geometric growth is used. Also note that when constant growth is used, the size of the internal buffers will always be the same as size
.
Create a buffered sequential pool for allocating memory blocks from the specified external buffer
having the specified size
(in bytes), or from an internal buffer (after the external buffer
is exhausted) where the buffer growth is limited to the specified maxBufferSize
(in bytes). Optionally specify a growthStrategy
used to control buffer growth. If a growthStrategy
is not specified, geometric growth is used. Optionally specify an alignmentStrategy
used to align allocated memory blocks. If an alignmentStrategy
is not specified, natural alignment is used. Optionally specify a basicAllocator
used to supply memory should the capacity of buffer
be exhausted. If basicAllocator
is 0, the currently installed default allocator is used. The behavior is undefined unless 0 < size
, size <= maxBufferSize
, and buffer
has at least size
bytes. Note that, due to alignment effects, it is possible that not all size
bytes of memory in buffer
can be used for allocation. Also note that when constant growth is used, the size of the internal buffers will always be the same as size
.