sourCEntral - mobile manpages

pdf

alloca

NOM

alloca - Allouer de la mémoire à libérer automatiquement

BIBLIOTHÈQUE

Bibliothèque C standard (libc, -lc)

SYNOPSIS

#include <alloca.h>

void *alloca(size_t size);

DESCRIPTION

La fonction alloca() alloue size octets dans la pile de l’appelant. Cet espace temporaire est automatiquement libéré lors du retour de la fonction ayant invoqué alloca().

VALEUR RENVOYÉE

La fonction alloca() renvoie un pointeur sur le début de la zone allouée. Si l’allocation provoque un dépassement de la pile, le comportement du programme est indéterminé.

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes(7).

img

STANDARDS

Cette fonction n’est pas dans POSIX.1.

La fonction alloca() est issue de PWB et de 32V et est présente dans tous leurs dérivés.

NOTES

La fonction alloca() dépend de la machine et du compilateur. Comme elle est allouée à partir de la pile, elle est plus rapide que malloc(3) et free(3). Dans certains cas, elle peut aussi simplifier la libération de la mémoire dans les applications qui utilisent longjmp(3) ou siglongjmp(3). Sinon, son utilisation est déconseillée.

Parce que l’espace alloué par alloca() est alloué sur la pile, il est automatiquement libéré si le retour de la fonction est sauté avec un appel à longjmp(3) ou siglongjmp(3).

L’espace alloué par alloca() n’est pas désalloué automatiquement si le pointeur y faisant référence devient seulement hors de portée.

N’essayez pas de libérer l’espace alloué par alloca() à l’aide de la fonction free(3) !

Par nécessité, alloca() est une fonction interne au compilateur, connue aussi sous le nom de __builtin_alloca(). Par défaut, les compilateurs modernes traduisent de façon automatique toutes les utilisations de alloca() en interne, mais cela n’est pas permis si une conformité aux standards est requise (-ansi, -std=c*), auquel cas <alloca.h> est requis, au cas où une dépendance de symbole serait émise.

Le fait que alloca() est une fonction interne signifie qu’il est impossible de prendre son adresse ou de changer son comportement en utilisant une bibliothèque différente.

Les tableaux de taille variable (VLA) font partie du standard C99, facultatifs depuis C11, et peuvent être utilisés dans un but similaire. Néanmoins, ils ne sont par portables en C++ standard, et étant variables, ils fonctionnent dans leur périmètre de bloc et n’ont pas d’interface de type allocateur, ce qui les rend inadaptés à l’implémentation de fonctionnalités comme strdupa(3).

BOGUES

Du fait de la nature de la pile, il est impossible de vérifier si l’allocation peut déborder de l’espace disponible et par conséquent rien n’indique une erreur (cependant, le programme recevra probablement un signal SIGSEGV s’il essaye d’accéder à l’espace non disponible).

Sur beaucoup de systèmes alloca() ne doit pas être utilisée au sein de la liste des arguments d’un appel de fonction, car l’espace de pile réservé par alloca() se trouverait alors au milieu de l’espace utilisé par les arguments de la fonction.

VOIR AUSSI

brk(2), longjmp(3), malloc(3)

TRADUCTION

La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan DOT rafin AT laposte DOT net>, Thierry Vignaud <tvignaud AT mandriva DOT com>, François Micaux, Alain Portal <aportal AT univ-montp2 DOT fr>, Jean-Philippe Guérard <fevrier AT tigreraye DOT org>, Jean-Luc Coulon (f5ibh) <jean-luc DOT coulon AT wanadoo DOT fr>, Julien Cristau <jcristau AT debian DOT org>, Thomas Huriaux <thomas DOT huriaux AT gmail DOT com>, Nicolas François <nicolas DOT francois AT centraliens DOT net>, Florentin Duneau <fduneau AT gmail DOT com>, Simon Paillard <simon DOT paillard AT resel DOT enst-bretagne DOT fr>, Denis Barbier <barbier AT debian DOT org>, David Prévot <david AT tilapin DOT org>, Grégoire Scano <gregoire DOT scano AT malloc DOT fr> et Jean-Pierre Giraud <jean-pierregiraud AT neuf DOT fr>

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 à debian-l10n-french.

pdf