ALLOCA
Section : Manuel du programmeur Linux (
3)
Mise à jour de la version anglaise : 17 juillet 2002
Index
Menu principal
NOM
alloca - Allouer de la mémoire qui est automatiquement libérée
SYNOPSIS
#include <alloca.h>
void *alloca(size_t size);
DESCRIPTION
La fonction
alloca()
alloue
size
octets dans l'espace de 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 échoue,
le comportement du programme est indéterminé.
CONFORMITÉ
Cette fonction n'est pas décrite par POSIX.1-2001.
Il semble que
alloca()
soit apparue dans 32V, PWB, PWB.2, BSD 3, et BSD 4.
Il existe une page de manuel la décrivant dans BSD 4.3.
Linux utilise la version GNU.
NOTES
La fonction
alloca()
est dépendante de la machine et du compilateur.
Pour certaines applications, son utilisation peut améliorer l'efficacité
comparé à l'utilisation de
malloc(3)
et
free(3).
Dans certains cas, elle simplifie également la libération de la mémoire
dans les applications qui utilisent
longjmp(3)
ou
siglongjmp(3).
Autrement, son utilisation est déconseillée.
Parce que l'espace alloué par
alloca()
est alloué dans le cadre de la pile, cet espace est automatiquement
libéré si la fonction de retour est sautée par un appel à
longjmp(3)
ou
siglongjmp(3).
N'essayez pas de libérer
(free(3))
de l'espace alloué avec
alloca() !
Notes sur la version GNU
Normalement,
gcc(1)
traduit l'appel de
alloca()
par du code « inline ».
Ceci n'est pas le cas si l'une des options
-ansi,
-std=c89,
-std=c99
ou
-no-builtin
est fournie
(et le fichier d'entête
<alloca.h>
n'est pas inclus).
Attention ! Par défaut, la version glibc de
<stdlib.h>
inclut
<alloca.h>
qui contient la ligne
#define alloca(size) __builtin_alloca (size)
avec toutes les conséquences fâcheuses que cela entraîne
si on a une fonction personnelle de ce nom.
Le fait que le code soit développé « inline » signifie qu'il est impossible
de prendre l'adresse de la fonction ou de changer son comportement
en utilisant une bibliothèque différente.
Le code « inline » consiste souvent en une seule instruction qui ajuste
le pointeur de pile et ne vérifie pas le débordement de pile.
Il n'y a donc pas de retour d'erreur de valeur NULL.
BOGUES
Aucune erreur n'est signalée si le cadre de la pile ne peut pas être
étendu.
(Toutefois, après un échec d'allocation, le programme recevra probablement un signal
SIGSEGV
s'il tente d'accéder à l'espace non alloué.)
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
Ce document est une traduction réalisée par Christophe Blaess
<http://www.blaess.fr/christophe/> le 22 octobre 1996
et révisée le 17 juillet 2008.
L'équipe de traduction a fait le maximum pour réaliser une adaptation
française de qualité. La version anglaise la plus à jour de ce document est
toujours consultable via la commande : « LANG=C man 3 alloca ».
N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute
erreur dans cette page de manuel.
Index
- NOM
-
- SYNOPSIS
-
- DESCRIPTION
-
- VALEUR RENVOYÉE
-
- CONFORMITÉ
-
- NOTES
-
- Notes sur la version GNU
-
- BOGUES
-
- VOIR AUSSI
-
- TRADUCTION
-
Dernière mise à jour : 17 juillet 2008