alloca   Début   Suivant   Sommaire   Préc.page.lue   Accueil
Section: Manuel du programmeur Linux (3)
Updated: 17 juillet 2002
Sommaire  



NOM   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
alloca - Allouer de la mémoire qui est automatiquement libérée  



SYNOPSIS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
#include <stdlib.h>

void *alloca (size_t size);  




DESCRIPTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
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   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
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É   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
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 y a une page de manuel la décrivant dans BSD 4.3. Linux utilise la version GNU.  




NOTES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
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 désallocation 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   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Normalement, gcc(1) traduit l'appel de alloca() par du code en-ligne. 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é en ligne 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 en ligne 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 NULL.  




BOGUES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
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 un signal SIGSEGV s'il tente d'accéder à l'espace non allloué.) 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   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
brk(2), longjmp(3), malloc(3)  



TRADUCTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

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 6 juin 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.


 



Sommaire   Début   Suivant   Sommaire   Préc.page.lue   Accueil
NOM
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
CONFORMITÉ
NOTES
Notes sur la version GNU
BOGUES
VOIR AUSSI
TRADUCTION

Ce document a été créé par man2html suivi de man2html.pl, le 17/10/2008 17:48:56, en utilisant les pages de 'man'.
 

Valid HTML 4.01 Transitional