#include <defaultallocator.h>
Default implementation of an allocator. An allocator is used by arrays, lists and other data structurs to allocate and release memory. By default this implementation of an allocator is used.
The DefaultAllocator guarantees that allocations of at least 64 bytes will have a 64 byte alignment (cache line). Smaller allocations of at least 32 bytes have an AVX-safe alignment. Everything smaller has at least an SSE-safe 16 byte alignment.
There might be rare cases when you need a special memory alignment, a different resize strategy or have to use a special memory area (stack, shared memory, ...). This can be done by writing a custom allocator and specifying it as parameter upon array construction. A custom allocator must implement the ComputeArraySize(), Alloc(), AllocClear(), Realloc() and Free() methods, but it doesn't (and usually shouldn't) inherit from DefaultAllocator. The allocator methods don't have to be static if your allocator requires member variables, but the DefaultAllocator doesn't and therefore uses static methods for better performance.
Please note that an allocator is copied upon array construction - it would be a bad idea if your custom allocator object would consist of more than a few variables.
THREADSAFE.
Static Public Member Functions | |
static Int | ComputeArraySize (Int currentSize, Int increment, Int minChunkSize) |
static MAXON_ATTRIBUTE_FORCE_INLINE void * | Alloc (Int32 s, MAXON_SOURCE_LOCATION_DECLARATION) |
static MAXON_ATTRIBUTE_FORCE_INLINE void * | Alloc (Int64 s, MAXON_SOURCE_LOCATION_DECLARATION) |
static MAXON_ATTRIBUTE_FORCE_INLINE void * | AllocClear (Int32 s, MAXON_SOURCE_LOCATION_DECLARATION) |
static MAXON_ATTRIBUTE_FORCE_INLINE void * | AllocClear (Int64 s, MAXON_SOURCE_LOCATION_DECLARATION) |
static MAXON_ATTRIBUTE_FORCE_INLINE void * | Realloc (void *p, Int32 n, MAXON_SOURCE_LOCATION_DECLARATION) |
static MAXON_ATTRIBUTE_FORCE_INLINE void * | Realloc (void *p, Int64 n, MAXON_SOURCE_LOCATION_DECLARATION) |
template<typename T > | |
static MAXON_ATTRIBUTE_FORCE_INLINE void | Free (T *&p) |
static MAXON_ATTRIBUTE_FORCE_INLINE Bool | IsCompatibleWithDefaultAllocator (void *) |
template<typename T > | |
static MAXON_FUNCTION void | DeleteInNextEpoch (T *object) |
Static Public Attributes | |
static const UInt | ALIGNMENT |
static const UInt | ALIGNMENT_MASK |
static const UInt | MIN_ALIGNMENT_MASK |
Static Private Member Functions | |
template<typename T > | |
static void | EpochDelete (T *o) |
Computes the new capacity for a growing array. THREADSAFE.
[in] | currentSize | Current number of elements. |
[in] | increment | Number of elements to be added (>= 1) |
[in] | minChunkSize | The minimum number of elements upon array creation. |
|
static |
Allocates a memory block. THREADSAFE. The memory is not cleared, it may contain a certain byte pattern in debug mode.
[in] | s | Block size in bytes (values < 0 will return nullptr) |
[in] | allocLocation | Pass MAXON_SOURCE_LOCATION(_NAME) to add the current source line and file. |
|
static |
Allocates a memory block. THREADSAFE. The memory is not cleared, it may contain a certain byte pattern in debug mode.
[in] | s | Block size in bytes (values < 0 will return nullptr) |
[in] | allocLocation | Pass MAXON_SOURCE_LOCATION(_NAME) to add the current source line and file. |
|
static |
Allocates a memory block and clears it. THREADSAFE.
[in] | s | Block size in bytes (values < 0 will return nullptr) |
[in] | allocLocation | Pass MAXON_SOURCE_LOCATION(_NAME) to add the current source line and file. |
|
static |
Allocates a memory block and clears it. THREADSAFE.
[in] | s | Block size in bytes (values < 0 will return nullptr) |
[in] | allocLocation | Pass MAXON_SOURCE_LOCATION(_NAME) to add the current source line and file. |
|
static |
Resizes a memory block. The content of the memory block is preserved up to the lesser of the new and old sizes, even if the block is moved to a new location. The additional memory is not cleared, it may contain a certain byte pattern in debug mode. In case that p is a nullptr the function behaves like Alloc. If the function fails to allocate the requested block of memory a nullptr is returned and the memory block pointed to by argument p is not deallocated (it is still valid with its contents unchanged). THREADSAFE.
[in] | p | Current memory block (can be nullptr) |
[in] | n | New block size in bytes (values < 0 will return nullptr) |
[in] | allocLocation | Pass MAXON_SOURCE_LOCATION(_NAME) to add the current source line and file. |
|
static |
Resizes a memory block. The content of the memory block is preserved up to the lesser of the new and old sizes, even if the block is moved to a new location. The additional memory is not cleared, it may contain a certain byte pattern in debug mode. In case that p is a nullptr the function behaves like Alloc. If the function fails to allocate the requested block of memory a nullptr is returned and the memory block pointed to by argument p is not deallocated (it is still valid with its contents unchanged). THREADSAFE.
[in] | p | Current memory block (can be nullptr) |
[in] | n | New block size in bytes (values < 0 will return nullptr) |
[in] | allocLocation | Pass MAXON_SOURCE_LOCATION(_NAME) to add the current source line and file. |
|
static |
Frees a memory block. THREADSAFE.
[in,out] | p | Memory block address (can be nullptr, will be nullptr after return) |
|
static |
Returns if a memory block allocated via this allocator can be reallocated or freed by the DefaultAllocator.
|
static |
|
staticprivate |
|
static |
|
static |
|
static |