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

NOM

       strdup, strndup, strdupa, strndupa - Dupliquer une chaîne

BIBLIOTHÈQUE

       Bibliothèque C standard (libc, -lc)

SYNOPSIS

       #include <string.h>

       char *strdup(const char *s);

       char *strndup(const char s[.n], size_t n);
       char *strdupa(const char *s);
       char *strndupa(const char s[.n], size_t n);

   Exigences    de    macros    de   test   de   fonctionnalités   pour   la   glibc   (consulter
   feature_test_macros(7)) :

       strdup() :
       _XOPEN_SOURCE >= 500
               || /* Depuis la glibc 2.12 : */ _POSIX_C_SOURCE >= 200809L
               || /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE

       strndup() :
           Depuis la glibc 2.10 :
               _POSIX_C_SOURCE >= 200809L
           Avant la glibc 2.10 :
               _GNU_SOURCE

       strdupa(), strndupa() :
           _GNU_SOURCE

DESCRIPTION

       La fonction strdup() renvoie un pointeur sur une nouvelle chaîne  de  caractères  qui  est
       dupliquée  depuis  s. La mémoire occupée par cette nouvelle chaîne est obtenue en appelant
       malloc(3), et peut (et doit) donc être libérée avec free(3).

       La fonction strndup() est identique, mais ne copie au plus que n octets.  Si  s  est  plus
       grande que n, seuls n octets sont copiés et l'octet NULL de fin (« \0 ») est ajouté.

       strdupa et strndupa sont similaires, mais utilisent alloca(3) pour allouer le tampon.

VALEUR RENVOYÉE

       En  cas  de succès, la fonction strdup() renvoie un pointeur sur la chaîne dupliquée. NULL
       est renvoyé s'il n'y avait pas  assez  de  mémoire  et  errno  est  défini  pour  indiquer
       l'erreur.

ERREURS

       ENOMEM Mémoire disponible insuffisante pour dupliquer la chaîne.

ATTRIBUTS

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

       ┌────────────────────────────────────────────────────────┬──────────────────────┬─────────┐
       │InterfaceAttributValeur  │
       ├────────────────────────────────────────────────────────┼──────────────────────┼─────────┤
       │strdup(), strndup(), strdupa(), strndupa()              │ Sécurité des threads │ MT-Safe │
       └────────────────────────────────────────────────────────┴──────────────────────┴─────────┘

STANDARDS

       strdup()
       strndup()
              POSIX.1-2008.

       strdupa()
       strndupa()
              GNU.

HISTORIQUE

       strdup()
              SVr4, 4.3BSD-Reno, POSIX.1-2001.

       strndup()
              POSIX.1-2008.

       strdupa()
       strndupa()
              GNU.

VOIR AUSSI

       alloca(3), calloc(3), free(3), malloc(3), realloc(3), string(3), wcsdup(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>  et  Frédéric  Hantrais
       <fhantrais@gmail.com>

       Cette  traduction  est  une  documentation libre ; veuillez vous reporter à la GNU General
       Public  License  version 3  ⟨https://www.gnu.org/licenses/gpl-3.0.html⟩   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⟩.