malloc_trim(3) — Linux manual page


malloc_trim(3)          Library Functions Manual          malloc_trim(3)

NAME         top

       malloc_trim - release free memory from the heap

LIBRARY         top

       Standard C library (libc, -lc)

SYNOPSIS         top

       #include <malloc.h>

       int malloc_trim(size_t pad);

DESCRIPTION         top

       The malloc_trim() function attempts to release free memory from
       the heap (by calling sbrk(2) or madvise(2) with suitable

       The pad argument specifies the amount of free space to leave
       untrimmed at the top of the heap.  If this argument is 0, only
       the minimum amount of memory is maintained at the top of the heap
       (i.e., one page or less).  A nonzero argument can be used to
       maintain some trailing space at the top of the heap in order to
       allow future allocations to be made without having to extend the
       heap with sbrk(2).

RETURN VALUE         top

       The malloc_trim() function returns 1 if memory was actually
       released back to the system, or 0 if it was not possible to
       release any memory.

ERRORS         top

       No errors are defined.

ATTRIBUTES         top

       For an explanation of the terms used in this section, see
       │ Interface                           Attribute     Value   │
       │ malloc_trim()                       │ Thread safety │ MT-Safe │

STANDARDS         top


VERSIONS         top

       glibc 2.0.

NOTES         top

       Only the main heap (using sbrk(2)) honors the pad argument;
       thread heaps do not.

       Since glibc 2.8 this function frees memory in all arenas and in
       all chunks with whole free pages.

       Before glibc 2.8 this function only freed memory at the top of
       the heap in the main arena.

SEE ALSO         top

       sbrk(2), malloc(3), mallopt(3)

COLOPHON         top

       This page is part of the man-pages (Linux kernel and C library
       user-space interface documentation) project.  Information about
       the project can be found at 
       ⟨⟩.  If you have a bug report
       for this manual page, see
       This page was obtained from the tarball man-pages-6.9.1.tar.gz
       fetched from
       ⟨⟩ on
       2024-06-26.  If you discover any rendering problems in this HTML
       version of the page, or you believe there is a better or more up-
       to-date source for the page, or you have corrections or
       improvements to the information in this COLOPHON (which is not
       part of the original manual page), send a mail to

Linux man-pages 6.9.1          2024-05-02                 malloc_trim(3)

Pages that refer to this page: mallinfo(3)malloc(3)mallopt(3)sd_event_add_memory_pressure(3)