Provided by: manpages-fr-dev_4.21.0-2_all bug

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).
       ┌──────────────────────────────────────────────────────────────────────┬──────────────────────┬─────────┐
       │ InterfaceAttributValeur  │
       ├──────────────────────────────────────────────────────────────────────┼──────────────────────┼─────────┤
       │ alloca()                                                             │ Sécurité des threads │ MT-Safe │
       └──────────────────────────────────────────────────────────────────────┴──────────────────────┴─────────┘

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éra‐
       tion  de  la mémoire dans les applications qui utilisent longjmp(3) ou siglongjmp(3). Sinon, son utilisa‐
       tion 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  de‐
       vient 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 __buil‐
       tin_alloca(). Par défaut, les compilateurs modernes traduisent de façon automatique toutes  les  utilisa‐
       tions  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  va‐
       riables, 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.rafin@laposte.net>,  Thierry  Vignaud  <tvi‐
       gnaud@mandriva.com>,  François  Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fe‐
       vrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau  <jcristau@de‐
       bian.org>,   Thomas   Huriaux   <thomas.huriaux@gmail.com>,  Nicolas  François  <nicolas.francois@centra‐
       liens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>,
       Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Grégoire Scano <gregoire.scano@mal‐
       loc.fr> et Jean-Pierre Giraud <jean-pierregiraud@neuf.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 à de‐
       bian-l10n-french@lists.debian.org.

Pages du manuel de Linux 6.03                   15 décembre 2022                                       alloca(3)