malloc_trim - Rendre disponible la mémoire libérée du tas
Bibliothèque C standard (
libc,
-lc)
#include <malloc.h>
int malloc_trim(size_t pad);
La fonction
malloc_trim() essaie de rendre disponible la mémoire
libérée du tas (en appelant
sbrk(2) ou
madvise(2)
avec les paramètres adéquats).
Le paramètre
pad indique la quantité d'espace disponible
à garder non désalloué au sommet du tas. Si ce
paramètre vaut
0, le strict minimum de mémoire
est conservé au sommet du tas (c'est-à-dire une page
mémoire ou moins). Une valeur non nulle permet de conserver de l'espace
disponible au sommet du tas pour éviter que les futures allocations
aient besoin d'agrandir le tas en appelant
sbrk(2).
La fonction
malloc_trim() renvoie
1 si la mémoire a
été rendue effectivement au système, ou
0 s'il n'a
pas été possible de rendre de la mémoire.
Aucune erreur n'est définie.
Pour une explication des termes utilisés dans cette section, consulter
attributes(7).
Interface |
Attribut |
Valeur |
malloc_trim() |
Sécurité des threads |
MT-Safe |
Cette fonction est une extension GNU.
Seul le tas principal (utilisant
sbrk(2)) respecte l'argument
pad ; ce n'est pas le cas des tas des fils d'exécution.
Depuis la glibc 2.8, cette fonction libère de la mémoire
dans toutes les arènes et dans tous les blocs contenant des pages
entièrement vides.
Avant la glibc 2.8 cette fonction ne libérait de la mémoire
qu'au sommet du tas de l'arène principale.
sbrk(2),
malloc(3),
mallopt(3)
La traduction française de cette page de manuel a été
créée par Christophe Blaess
<
https://www.blaess.fr/christophe/>, Stéphan Rafin
<
[email protected]>, Thierry Vignaud
<
[email protected]>, François Micaux, Alain Portal
<
[email protected]>, Jean-Philippe Guérard
<
[email protected]>, Jean-Luc Coulon (f5ibh)
<
[email protected]>, Julien Cristau
<
[email protected]>, Thomas Huriaux <
[email protected]>,
Nicolas François <
[email protected]>, Florentin
Duneau <
[email protected]>, Simon Paillard
<
[email protected]>, Denis Barbier
<
[email protected]>, David Prévot <
[email protected]> et
Grégoire Scano <
[email protected]>
Cette traduction est une documentation libre ; veuillez vous reporter
à la
GNU
General Public License version 3 concernant les conditions de copie
et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.
Si vous découvrez un bogue dans la traduction de cette page de manuel,
veuillez envoyer un message à
[email protected]