max_fixed_size Class
The latest version of this topic can be found at max_fixed_size Class.
Describes a max class object that limits a freelist object to a fixed maximum length.
Syntax
template <std::size_t Max>
class max_fixed_size
Parameters
Parameter | Description |
---|---|
Max |
The max class that determines the maximum number of elements to store in the freelist . |
Constructors
max_fixed_size | Constructs an object of type max_fixed_size . |
Member Functions
allocated | Increments the count of allocated memory blocks. |
deallocated | Decrements the count of allocated memory blocks. |
full | Returns a value that specifies whether more memory blocks should be added to the free list. |
released | Decrements the count of memory blocks on the free list. |
saved | Increments the count of memory blocks on the free list. |
Requirements
Header: <allocators>
Namespace: stdext
max_fixed_size::allocated
Increments the count of allocated memory blocks.
void allocated(std::size_t _Nx = 1);
Parameters
Parameter | Description |
---|---|
_Nx |
The increment value. |
Remarks
The member function does nothing. This member function is called after each successful call by cache_freelist::allocate
to operator new
. The argument _Nx
is the number of memory blocks in the chunk allocated by operator new
.
max_fixed_size::deallocated
Decrements the count of allocated memory blocks.
void deallocated(std::size_t _Nx = 1);
Parameters
Parameter | Description |
---|---|
_Nx |
The increment value. |
Remarks
The member function does nothing. This member function is called after each call by cache_freelist::deallocate
to operator delete
. The argument _Nx
is the number of memory blocks in the chunk deallocated by operator delete
.
max_fixed_size::full
Returns a value that specifies whether more memory blocks should be added to the free list.
bool full();
Return Value
true
if Max <= _Nblocks
; otherwise, false
.
Remarks
This member function is called by cache_freelist::deallocate
. If the call returns true
, deallocate
puts the memory block on the free list; if it returns false, deallocate
calls operator delete
to deallocate the block.
max_fixed_size::max_fixed_size
Constructs an object of type max_fixed_size
.
max_fixed_size();
Remarks
This constructor initializes the stored value _Nblocks
to zero.
max_fixed_size::released
Decrements the count of memory blocks on the free list.
void released();
Remarks
Decrements the stored value _Nblocks
. The released
member function of the current max class is called by cache_freelist::allocate
whenever it removes a memory block from the free list.
max_fixed_size::saved
Increments the count of memory blocks on the free list.
void saved();
Remarks
This member function increments the stored value _Nblocks
. This member function is called by cache_freelist::deallocate
whenever it puts a memory block on the free list.