bes Updated for version 3.21.1
The Backend Server (BES) is the lower two tiers of the Hyrax data server
|
Default memory allocator used by the parser and DOM. More...
#include <allocators.h>
Public Member Functions | |
size_t | Capacity () const |
Computes the total capacity of allocated memory chunks. | |
void | Clear () |
Deallocates all memory chunks, excluding the user-supplied buffer. | |
void * | Malloc (size_t size) |
Allocates a memory block. (concept Allocator) | |
MemoryPoolAllocator (size_t chunkSize=kDefaultChunkCapacity, BaseAllocator *baseAllocator=0) | |
Constructor with chunkSize. | |
MemoryPoolAllocator (void *buffer, size_t size, size_t chunkSize=kDefaultChunkCapacity, BaseAllocator *baseAllocator=0) | |
Constructor with user-supplied buffer. | |
void * | Realloc (void *originalPtr, size_t originalSize, size_t newSize) |
Resizes a memory block (concept Allocator) | |
size_t | Size () const |
Computes the memory blocks allocated. | |
~MemoryPoolAllocator () | |
Destructor. | |
Static Public Member Functions | |
static void | Free (void *ptr) |
Frees a memory block (concept Allocator) | |
Static Public Attributes | |
static const bool | kNeedFree = false |
Tell users that no need to call Free() with this allocator. (concept Allocator) | |
Default memory allocator used by the parser and DOM.
This allocator allocate memory blocks from pre-allocated memory chunks.
It does not free memory blocks. And Realloc() only allocate new memory.
The memory chunks are allocated by BaseAllocator, which is CrtAllocator by default.
User may also supply a buffer as the first chunk.
If the user-buffer is full then additional chunks are allocated by BaseAllocator.
The user-buffer is not deallocated by this allocator.
BaseAllocator | the allocator type for allocating memory chunks. Default is CrtAllocator. |
Definition at line 115 of file allocators.h.
|
inline |
Constructor with chunkSize.
chunkSize | The size of memory chunk. The default is kDefaultChunkSize. |
baseAllocator | The allocator for allocating memory chunks. |
Definition at line 123 of file allocators.h.
|
inline |
Constructor with user-supplied buffer.
The user buffer will be used firstly. When it is full, memory pool allocates new chunk with chunk size.
The user buffer will not be deallocated when this allocator is destructed.
buffer | User supplied buffer. |
size | Size of the buffer in bytes. It must at least larger than sizeof(ChunkHeader). |
chunkSize | The size of memory chunk. The default is kDefaultChunkSize. |
baseAllocator | The allocator for allocating memory chunks. |
Definition at line 138 of file allocators.h.
|
inline |
Destructor.
This deallocates all memory chunks, excluding the user-supplied buffer.
Definition at line 152 of file allocators.h.
|
inline |
Computes the total capacity of allocated memory chunks.
Definition at line 171 of file allocators.h.
|
inline |
Deallocates all memory chunks, excluding the user-supplied buffer.
Definition at line 158 of file allocators.h.
|
inlinestatic |
Frees a memory block (concept Allocator)
Definition at line 238 of file allocators.h.
|
inline |
Allocates a memory block. (concept Allocator)
Definition at line 189 of file allocators.h.
|
inline |
Resizes a memory block (concept Allocator)
Definition at line 204 of file allocators.h.
|
inline |
Computes the memory blocks allocated.
Definition at line 181 of file allocators.h.
|
static |
Tell users that no need to call Free() with this allocator. (concept Allocator)
Definition at line 117 of file allocators.h.