[Overview][Types][Classes][Index] |
[Properties (by Name)] [Methods (by Name)] [Events (by Name)]
Memory manager for fixed memory blocks which does not free any memory
Source position: pooledmm.pp line 73
type TNonFreePooledMemManager = class end; |
||
public |
||
ClearOnCreate: Boolean; |
|
Determines whether newly allocated memory should be cleared |
|
Size of an item in the list |
|
procedure Clear; |
|
Clears the memory |
constructor Create(); |
|
Creates a new instance of TNonFreePooledMemManager |
destructor Destroy; override; |
|
Removes the TNonFreePooledMemManager instance from memory |
function NewItem; |
|
Return a pointer to a new memory block |
procedure EnumerateItems(); |
|
Enumerate all items in the list |
|
Memory manager for fixed memory blocks which does not free any memory |
|
| | ||
TObject |
TNonFreePooledMemManager keeps a list of fixed-size memory blocks in memory. Each block has the same size, making it suitable for storing a lot of records of the same type. It does not free the items stored in it, except when the list is cleared as a whole.
It allocates memory for the blocks in a exponential way, i.e. each time a new block of memory must be allocated, it's size is the double of the last block. The first block will contain 8 items.