|
LMMS
|
#include <ArrayAllocationBase.h>
Public Member Functions | |
| ArrayAllocationBase () noexcept | |
| ~ArrayAllocationBase () noexcept | |
| bool | setAllocatedSize (const size_t numNewElements) noexcept |
| bool | ensureAllocatedSize (const size_t minNumElements) noexcept |
| bool | shrinkToNoMoreThan (const size_t maxNumElements) noexcept |
| void | swapWith (ArrayAllocationBase< ElementType > &other) noexcept |
| void | moveMemory (ElementType *target, const ElementType *source, const size_t numElements) noexcept |
Public Attributes | |
| HeapBlock< ElementType > | elements |
| size_t | numAllocated |
Implements some basic array storage allocation functions.
This class isn't really for public use - it's used by the other array classes, but might come in handy for some purposes.
|
inlinenoexcept |
Creates an empty array.
|
inlinenoexcept |
Destructor.
|
inlinenoexcept |
Increases the amount of storage allocated if it is less than a given amount.
This will retain any data currently held in the array, but will add extra space at the end to make sure there it's at least as big as the size passed in. If it's already bigger, no action is taken.
| minNumElements | the minimum number of elements that are needed |
|
inlinenoexcept |
|
inlinenoexcept |
Changes the amount of storage allocated.
This will retain any data currently held in the array, and either add or remove extra space at the end.
| numNewElements | the number of elements that are needed |
|
inlinenoexcept |
Minimises the amount of storage allocated so that it's no more than the given number of elements.
|
inlinenoexcept |
Swap the contents of two objects.
| HeapBlock<ElementType> water::ArrayAllocationBase< ElementType >::elements |
| size_t water::ArrayAllocationBase< ElementType >::numAllocated |