docs/Writerside/topics/memory.md

Tue, 23 Dec 2025 17:08:14 +0100

author
Mike Becker <universe@uap-core.de>
date
Tue, 23 Dec 2025 17:08:14 +0100
changeset 1662
527ac061b247
parent 1318
12fa1d37fe48
permissions
-rw-r--r--

fixes that cx_list_default_insert_array() has the wrong nonnull attribute when used for cxListEmplaceArray()

fixes #790

# Memory Management

With the `CxAllocator` interface UCX provides the possibility to use custom allocator functions for different purposes.
Many UCX functions support the use of specialized allocators or provide a second function suffixed with `_a`.

For convenience, functions that are not explicitly requesting an allocator - like e.g. `cx_strdup_a()` - also accept
`NULL` as an allocator, in which case the [default allocator](allocator.h.md#default-allocator) is used.

Additionally, UCX also provides a [memory pool](mempool.h.md) implementation of the allocator interface.

> Although not part of the public API, UCX is also implementing the allocator interface
> in its own test suite: `CxTestingAllocator`. This allocator keeps track of memory allocations
> and deallocations with the goal to detect memory management errors.  

mercurial