33 template <
class T,
int chunkSize = 128 >
class MemoryPool {
77 m_chunks.push_back(
reinterpret_cast<T*
>(malloc(chunkSize *
sizeof(T))));
88 size_t needed_chunks = n / chunkSize + 1;
90 while (
m_chunks.size() < needed_chunks) {
91 m_chunks.push_back(
reinterpret_cast<T*
>(malloc(chunkSize *
sizeof(T))));
101 free(
reinterpret_cast<void*
>(ptr));
Class to provide a constant access time memory pool for one kind of objects.
~MemoryPool()
Free allocated memory.
MemoryPool(int n=0)
Constructor.
size_t size() const
Return number of elements currently stored.
T * operator[](size_t i)
Return pointer to memory segment for element i, no range check.
T * add()
Returns an pointer to the next free memory segment, allocating additional memory if necessary.
T * at(size_t i)
Return pointer to memory segment for element i, including range check.
void release_memory()
Release all allocated memory, called automatically upon destruction.
void clear()
Clear number of entries, does not free memory or call destructors.
std::vector< T * > m_chunks
Pointers to all allocated memory chunks.
void reserve(size_t n)
Make sure there is enough memory allocated for n elements.
size_t m_entries
Number of occupied entries.
Abstract base class for different kinds of events.