Provided by: manpages-fr-dev_4.26.0-1_all bug

NOM

       stdarg, va_start, va_arg, va_end, va_copy - Liste variable d'arguments

BIBLIOTHÈQUE

       Bibliothèque C standard (libc, -lc)

SYNOPSIS

       #include <stdarg.h>

       void va_start(va_list ap, last);
       type va_arg(va_list ap, type);
       void va_end(va_list ap);
       void va_copy(va_list dest, va_list src);

DESCRIPTION

       Une  fonction  peut  être  appelée avec un nombre variable d'arguments, eux-mêmes de types variables. Une
       telle fonction est dite « variadique ». Le fichier  d'en-tête  <stdarg.h>  déclare  un  type  va_list  et
       définit trois macros permettant de parcourir la liste d'arguments dont le nombre et les types ne sont pas
       connus par la fonction appelée.

       La fonction appelée doit déclarer un objet de type va_list utilisé par les macros va_start(), va_arg() et
       va_end().

   va_start()
       La macro va_start() initialise ap pour les utilisations ultérieures de va_arg() et va_end(), et doit donc
       être appelée en premier.

       Le  paramètre dernier est le nom du dernier paramètre avant la liste variable de paramètres, c'est-à-dire
       le dernier paramètre dont la fonction connaisse le type.

       Comme l'adresse de ce paramètre est utilisée dans la macro va_start(), il ne doit pas être déclaré  comme
       une variable en registre, ni comme un type fonction ou tableau.

   va_arg()
       La  macro  va_arg()  se  développe  en une expression qui a le type et la valeur de l'argument suivant de
       l'appel. Le paramètre ap est la va_list ap initialisée par va_start(). Chaque appel de  va_arg()  modifie
       ap  pour  que l'appel suivant renvoie le paramètre suivant. Le paramètre type est le nom du type, indiqué
       de telle manière qu'un pointeur sur un objet de ce type puisse être déclaré  simplement  en  ajoutant  un
       astérisque à type.

       La  première  utilisation  de  la  macro  va_arg()  après  celle de va_start() renvoie l'argument suivant
       dernier. Les invocations successives renvoient les valeurs des arguments restants.

       S'il n'y a pas d'argument suivant, ou si type n'est pas compatible avec  le  type  du  prochain  argument
       effectif, des erreurs imprévisibles se produiront.

       Si  ap  est passé à une fonction qui utilise va_arg(ap,type) alors la valeur de ap est indéfinie après le
       retour de cette fonction.

   va_end()
       À chaque invocation de va_start() doit correspondre une invocation de va_end()  dans  la  même  fonction.
       Après l'appel va_end(ap) la variable ap est indéfinie. Plusieurs traversées de la liste sont possibles, à
       condition  que  chacune  soit  encadrée  par  va_start() et va_end(). va_end() peut être une macro ou une
       fonction.

   va_copy()
       La macro va_copy() copie la liste d'arguments variables (précédemment  initialisés)  src  vers  dest.  Le
       comportement serait similaire si va_start() était appliqué à dest avec le même argument dernier, suivi du
       même nombre d'invocations de va_arg() qui seraient utilisées pour atteindre l'état actuel de src.

       Une  implémentation  évidente  est  de  représenter  va_list  par un pointeur dans la pile de la fonction
       variadique. Dans une telle situation (de  loin  la  plus  courante),  rien  ne  semble  s'opposer  à  une
       affectation

           va_list aq = ap;

       Malheureusement,  il  y  a  aussi  des  systèmes qui créent une table de pointeurs (de longueur 1), et on
       devrait écrire

           va_list aq;
           *aq = *ap;

       De plus, sur les systèmes où les paramètres sont passés dans des registres, il peut être nécessaire  pour
       va_start()  d'allouer  de  la mémoire, d'y enregistrer les paramètres ainsi que l'indication du paramètre
       suivant, afin que va_arg() puisse balayer la liste. Ainsi va_end() pourra  libérer  la  mémoire  allouée.
       Pour  gérer  ces  situations,  C99 ajoute une macro va_copy(), afin que les affectations ci-dessus soient
       remplacées par

           va_list aq;
           va_copy(aq, ap);
           ...
           va_end(aq);

       À chaque invocation de va_copy() doit correspondre une invocation de  va_end()  dans  la  même  fonction.
       Certains systèmes qui ne disposent pas de va_copy() ont une macro __va_copy() à la place, puisque c'était
       le nom proposé auparavant.

ATTRIBUTS

       Pour une explication des termes utilisés dans cette section, consulter attributes(7).
       ┌──────────────────────────────────────────────────────────────┬──────────────────────┬─────────────────┐
       │ InterfaceAttributValeur          │
       ├──────────────────────────────────────────────────────────────┼──────────────────────┼─────────────────┤
       │ va_start(), va_end(), va_copy()                              │ Sécurité des threads │ MT-Safe         │
       ├──────────────────────────────────────────────────────────────┼──────────────────────┼─────────────────┤
       │ va_arg()                                                     │ Sécurité des threads │ MT-Safe race:ap │
       └──────────────────────────────────────────────────────────────┴──────────────────────┴─────────────────┘

STANDARDS

       C11, POSIX.1-2008.

HISTORIQUE

       va_start()
       va_arg()
       va_end()
              C89, POSIX.1-2001.

       va_copy()
              C99, POSIX.1-2001.

AVERTISSEMENTS

       Contrairement aux macros varargs() historiques, les macros stdarg() ne permettent pas aux programmeurs de
       coder  une  fonction  sans  aucun  argument  fixe.  Ce  problème  se pose principalement en convertissant
       directement du code utilisant varargs() en code utilisant stdarg(), mais il se pose  également  pour  les
       fonctions qui désirent passer tous leurs arguments à une fonction utilisant un argument va_list telle que
       vfprintf(3).

EXEMPLES

       La fonction foo() prend une chaîne de caractères de mise en forme, et affiche les arguments associés avec
       chaque format correspondant au type indiqué.

       #include <stdio.h>
       #include <stdarg.h>

       void
       foo(char *fmt, ...) /* '...' is C syntax for a variadic function */

       {
           va_list ap;
           int d;
           char c;
           char *s;

           va_start(ap, fmt);
           while (*fmt)
               switch (*fmt++) {
               case 's':              /* string */
                   s = va_arg(ap, char *);
                   printf("string %s\n", s);
                   break;
               case 'd':              /* int */
                   d = va_arg(ap, int);
                   printf("int %d\n", d);
                   break;
               case 'c':              /* char */
                   /* need a cast here since va_arg only
                      takes fully promoted types */
                   c = (char) va_arg(ap, int);
                   printf("char %c\n", c);
                   break;
               }
           va_end(ap);
       }

VOIR AUSSI

       vprintf(3), vscanf(3), vsyslog(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
       <tvignaud@mandriva.com>,  François  Micaux,  Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard
       <fevrier@tigreraye.org>,   Jean-Luc   Coulon   (f5ibh)   <jean-luc.coulon@wanadoo.fr>,   Julien   Cristau
       <jcristau@debian.org>,      Thomas      Huriaux      <thomas.huriaux@gmail.com>,     Nicolas     François
       <nicolas.francois@centraliens.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>,    Cédric    Boutillier     <cedric.boutillier@gmail.com>,     Frédéric     Hantrais
       <fhantrais@gmail.com> et Grégoire Scano <gregoire.scano@malloc.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@lists.debian.org.

Pages du manuel de Linux 6.9.1                    15 juin 2024                                         stdarg(3)